প্রায়শই আপনার ফাংশনগুলির জন্য অতিরিক্ত কনফিগারেশনের প্রয়োজন হয়, যেমন তৃতীয় পক্ষের API কী বা টিউনেবল সেটিংস। Firebase SDK for Cloud Functions আপনার প্রকল্পের জন্য এই ধরণের ডেটা সংরক্ষণ এবং পুনরুদ্ধার করা সহজ করার জন্য অন্তর্নির্মিত পরিবেশ কনফিগারেশন অফার করে।
আপনি এই বিকল্পগুলির মধ্যে একটি বেছে নিতে পারেন:
- প্যারামিটারাইজড কনফিগারেশন (বেশিরভাগ পরিস্থিতিতে প্রস্তাবিত)। এটি দৃঢ়ভাবে টাইপ করা পরিবেশ কনফিগারেশন প্রদান করে যা স্থাপনের সময় যাচাই করা প্যারামিটার সহ, যা ত্রুটি প্রতিরোধ করে এবং ডিবাগিংকে সহজ করে।
- এনভায়রনমেন্ট ভেরিয়েবলের ফাইল-ভিত্তিক কনফিগারেশন। এই পদ্ধতির সাহায্যে, আপনি এনভায়রনমেন্ট ভেরিয়েবল লোড করার জন্য ম্যানুয়ালি একটি dotenv ফাইল তৈরি করতে পারেন।
বেশিরভাগ ব্যবহারের ক্ষেত্রে, প্যারামিটারাইজড কনফিগারেশন সুপারিশ করা হয়। এই পদ্ধতিটি রানটাইম এবং ডিপ্লয় সময় উভয় সময়েই কনফিগারেশন মান উপলব্ধ করে এবং সমস্ত প্যারামিটারের একটি বৈধ মান না থাকলে ডিপ্লয়মেন্ট ব্লক করা হয়। বিপরীতভাবে, ডিপ্লয় সময় পরিবেশ ভেরিয়েবল সহ কনফিগারেশন উপলব্ধ নয়।
প্যারামিটারাইজড কনফিগারেশন
Cloud Functions for Firebase আপনার কোডবেসের ভিতরে কনফিগারেশন প্যারামিটারগুলিকে ঘোষণামূলকভাবে সংজ্ঞায়িত করার জন্য একটি ইন্টারফেস প্রদান করে। এই প্যারামিটারগুলির মান ফাংশন স্থাপনের সময়, স্থাপন এবং রানটাইম বিকল্পগুলি সেট করার সময় এবং কার্যকর করার সময় উভয়ই উপলব্ধ। এর অর্থ হল যে সমস্ত প্যারামিটারের একটি বৈধ মান না থাকলে CLI স্থাপনকে ব্লক করবে।
আপনার কোডে প্যারামিটার নির্ধারণ করতে, এই মডেলটি অনুসরণ করুন:
const functions = require('firebase-functions/v1');
const { defineInt, defineString } = require('firebase-functions/params');
// Define some parameters
const minInstancesConfig = defineInt('HELLO_WORLD_MININSTANCES');
const welcomeMessage = defineString('WELCOME_MESSAGE');
// To use configured parameters inside the config for a function, provide them
// directly. To use them at runtime, call .value() on them.
export const helloWorld = functions.runWith({ minInstances: minInstancesConfig}).https.onRequest(
(req, res) => {
res.send(`${welcomeMessage.value()}! I am a function.`);
}
);
প্যারামিটারাইজড কনফিগারেশন ভেরিয়েবল সহ একটি ফাংশন স্থাপন করার সময়, Firebase CLI প্রথমে স্থানীয় .env ফাইল থেকে তাদের মান লোড করার চেষ্টা করে। যদি সেগুলি সেই ফাইলগুলিতে উপস্থিত না থাকে এবং কোনও default সেট না থাকে, তাহলে CLI স্থাপনের সময় মানগুলির জন্য অনুরোধ করবে এবং তারপর স্বয়ংক্রিয়ভাবে আপনার functions/ ডিরেক্টরিতে .env.<project_ID> নামক একটি .env ফাইলে তাদের মানগুলি সংরক্ষণ করবে:
$ firebase deploy
i functions: preparing codebase default for deployment
? Enter a string value for ENVIRONMENT: prod
i functions: Writing new parameter values to disk: .env.projectId
…
$ firebase deploy
i functions: Loaded environment variables from .env.projectId
আপনার ডেভেলপমেন্ট ওয়ার্কফ্লোর উপর নির্ভর করে, জেনারেট করা .env.<project_ID> ফাইলটি ভার্সন কন্ট্রোলে যোগ করা কার্যকর হতে পারে।
গ্লোবাল স্কোপে প্যারামিটার ব্যবহার করা
স্থাপনার সময়, আপনার প্যারামিটারের প্রকৃত মান পাওয়ার আগেই আপনার ফাংশন কোড লোড এবং পরিদর্শন করা হয়। এর অর্থ হল গ্লোবাল স্কোপের সময় প্যারামিটারের মান আনার ফলে স্থাপনা ব্যর্থ হয়। যেসব ক্ষেত্রে আপনি একটি প্যারামিটার ব্যবহার করে একটি গ্লোবাল মান শুরু করতে চান, সেক্ষেত্রে initialization callback onInit() ব্যবহার করুন। এই কলব্যাকটি প্রোডাকশনে চলমান যেকোনো ফাংশনের আগে চলে কিন্তু স্থাপনার সময় কল করা হয় না, তাই এটি একটি প্যারামিটারের মান অ্যাক্সেস করার জন্য একটি নিরাপদ জায়গা।
const { GoogleGenerativeAI } = require('@google/generative-ai');
const { defineSecret } = require('firebase-functions/params');
const { onInit } = require('firebase-functions/v1');
const apiKey = defineSecret('GOOGLE_API_KEY');
let genAI;
onInit(() => {
genAI = new GoogleGenerativeAI(apiKey.value());
})
CLI আচরণ কনফিগার করুন
প্যারামিটারগুলি একটি Options অবজেক্ট দিয়ে কনফিগার করা যেতে পারে যা CLI কীভাবে মানগুলির জন্য প্রম্পট করবে তা নিয়ন্ত্রণ করে। নিম্নলিখিত উদাহরণটি একটি ফোন নম্বরের ফর্ম্যাট যাচাই করার জন্য, একটি সহজ নির্বাচন বিকল্প প্রদান করার জন্য এবং Firebase প্রকল্প থেকে স্বয়ংক্রিয়ভাবে একটি নির্বাচন বিকল্প পূরণ করার জন্য বিকল্পগুলি সেট করে:
const { defineString } = require('firebase-functions/params');
const welcomeMessage = defineString('WELCOME_MESSAGE', {default: 'Hello World',
description: 'The greeting that is returned to the caller of this function'});
const onlyPhoneNumbers = defineString('PHONE_NUMBER', {input: {text:
{validationRegex: /\d{3}-\d{3}-\d{4}/, validationErrorMessage: "Please enter
a phone number in the format XXX-YYY-ZZZZ"}}});
const selectedOption = defineString('PARITY', {input: {select: {options:
[{value: "odd"}, {value: "even"}]}}})
const storageBucket = defineString('BUCKET', {input: {resource: {type:
"storage.googleapis.com/Bucket"}}, description: "This will automatically
populate the selector field with the deploying Cloud Project’s
storage buckets"})
প্যারামিটারের ধরণ
প্যারামিটারাইজড কনফিগারেশন প্যারামিটার মানগুলির জন্য শক্তিশালী টাইপিং প্রদান করে এবং ক্লাউড সিক্রেট ম্যানেজার থেকে গোপনীয়তা সমর্থন করে। সমর্থিত প্রকারগুলি হল:
- গোপন
- স্ট্রিং
- বুলিয়ান
- পূর্ণসংখ্যা
- ভাসা
প্যারামিটার সংজ্ঞায়িত করার ফাংশন সম্পর্কে তথ্যের জন্য params নেমস্পেস রেফারেন্স দেখুন।
প্যারামিটার মান এবং রাশি
ফায়ারবেস আপনার প্যারামিটারগুলি স্থাপনের সময় এবং আপনার ফাংশনটি কার্যকর করার সময় উভয়ই মূল্যায়ন করে। এই দ্বৈত পরিবেশের কারণে, প্যারামিটার মানগুলির তুলনা করার সময় এবং আপনার ফাংশনগুলির জন্য রানটাইম বিকল্পগুলি সেট করার জন্য সেগুলি ব্যবহার করার সময় কিছু অতিরিক্ত সতর্কতা অবলম্বন করা উচিত।
রানটাইম বিকল্প হিসেবে আপনার ফাংশনে একটি প্যারামিটার পাস করতে, এটি সরাসরি পাস করুন:
const functions = require('firebase-functions/v1');
const { defineInt} = require('firebase-functions/params');
const minInstancesConfig = defineInt('HELLO\_WORLD\_MININSTANCES');
export const helloWorld = functions.runWith({ minInstances: minInstancesConfig}).https.onRequest(
(req, res) => {
//…
অতিরিক্তভাবে, কোন বিকল্পটি বেছে নেবেন তা জানার জন্য যদি আপনাকে কোনও প্যারামিটারের সাথে তুলনা করতে হয়, তাহলে মান পরীক্ষা করার পরিবর্তে আপনাকে বিল্ট-ইন তুলনাকারী ব্যবহার করতে হবে:
const functions = require('firebase-functions/v1');
const { defineBool } = require('firebase-functions/params');
const environment = params.defineString(‘ENVIRONMENT’, {default: ‘dev’});
// use built-in comparators
const minInstancesConfig =environment.equals('PRODUCTION').thenElse(10, 1);
export const helloWorld = functions.runWith({ minInstances: minInstancesConfig}).https.onRequest(
(req, res) => {
//…
শুধুমাত্র রানটাইমে ব্যবহৃত প্যারামিটার এবং প্যারামিটার এক্সপ্রেশনগুলি তাদের value ফাংশন দিয়ে অ্যাক্সেস করা যেতে পারে:
const functions = require('firebase-functions/v1');
const { defineString } = require('firebase-functions/params');
const welcomeMessage = defineString('WELCOME_MESSAGE');
// To use configured parameters inside the config for a function, provide them
// directly. To use them at runtime, call .value() on them.
export const helloWorld = functions.https.onRequest(
(req, res) => {
res.send(`${welcomeMessage.value()}! I am a function.`);
}
);
অন্তর্নির্মিত পরামিতি
ক্লাউড ফাংশন SDK তিনটি পূর্ব-নির্ধারিত প্যারামিটার অফার করে, firebase-functions/params সাবপ্যাকেজ থেকে পাওয়া যায়:
-
projectID— ক্লাউড প্রকল্প যেখানে ফাংশনটি চলছে। -
databaseURL— ফাংশনের সাথে সম্পর্কিত রিয়েলটাইম ডাটাবেস ইনস্ট্যান্সের ইউআরএল (যদি ফায়ারবেস প্রকল্পে সক্ষম করা থাকে)। -
storageBucket— ফাংশনের সাথে যুক্ত ক্লাউড স্টোরেজ বাকেট (যদি Firebase প্রকল্পে সক্ষম করা থাকে)।
এইগুলি সকল ক্ষেত্রে ব্যবহারকারী-সংজ্ঞায়িত স্ট্রিং প্যারামিটারের মতো কাজ করে, তবে যেহেতু তাদের মানগুলি সর্বদা Firebase CLI-তে পরিচিত, তাই তাদের মানগুলি স্থাপনের সময় কখনই অনুরোধ করা হবে না বা .env ফাইলগুলিতে সংরক্ষণ করা হবে না।
গোপন পরামিতি
defineSecret() ব্যবহার করে সংজ্ঞায়িত Secret ধরণের প্যারামিটারগুলি স্ট্রিং প্যারামিটারগুলিকে প্রতিনিধিত্ব করে যার একটি মান ক্লাউড সিক্রেট ম্যানেজারে সংরক্ষিত থাকে। স্থানীয় .env ফাইলের বিপরীতে পরীক্ষা করার এবং অনুপস্থিত থাকলে ফাইলটিতে একটি নতুন মান লেখার পরিবর্তে, secret প্যারামিটারগুলি ক্লাউড সিক্রেট ম্যানেজারে অস্তিত্ব পরীক্ষা করে এবং স্থাপনের সময় একটি নতুন সিক্রেটের মান সম্পর্কে ইন্টারেক্টিভভাবে প্রম্পট করে।
এইভাবে সংজ্ঞায়িত গোপন প্যারামিটারগুলি অবশ্যই পৃথক ফাংশনের সাথে আবদ্ধ হতে হবে যার অ্যাক্সেস থাকা উচিত:
const functions = require('firebase-functions/v1');
const { defineSecret } = require('firebase-functions/params');
const discordApiKey = defineSecret('DISCORD_API_KEY');
export const postToDiscord = functions.runWith({ secrets: [discordApiKey] }).https.onRequest(
(req, res) => {
const apiKey = discordApiKey.value();
//…
পরিবেশের ভেরিয়েবল
Cloud Functions for Firebase আপনার অ্যাপ্লিকেশন রানটাইমে .env ফাইলে নির্দিষ্ট পরিবেশ ভেরিয়েবল লোড করার জন্য dotenv ফাইল ফর্ম্যাট সমর্থন করে। একবার স্থাপন করা হলে, পরিবেশ ভেরিয়েবলগুলি process.env ইন্টারফেসের মাধ্যমে পড়া যেতে পারে।
এইভাবে আপনার পরিবেশ কনফিগার করতে, আপনার প্রকল্পে একটি .env ফাইল তৈরি করুন, পছন্দসই ভেরিয়েবল যোগ করুন এবং স্থাপন করুন:
আপনার
functions/ডিরেক্টরিতে একটি.envফাইল তৈরি করুন:# Directory layout: # my-project/ # firebase.json # functions/ # .env # package.json # index.jsসম্পাদনার জন্য
.envফাইলটি খুলুন এবং পছন্দসই কীগুলি যোগ করুন। উদাহরণস্বরূপ:PLANET=Earth AUDIENCE=Humansফাংশন স্থাপন করুন এবং পরিবেশের ভেরিয়েবল লোড হয়েছে কিনা তা যাচাই করুন:
firebase deploy --only functions # ... # i functions: Loaded environment variables from .env. # ...
একবার আপনার কাস্টম এনভায়রনমেন্ট ভেরিয়েবল স্থাপন করা হয়ে গেলে, আপনার ফাংশন কোড process.env সিনট্যাক্সের মাধ্যমে সেগুলি অ্যাক্সেস করতে পারবে:
// Responds with "Hello Earth and Humans"
exports.hello = functions.https.onRequest((request, response) => {
response.send(`Hello ${process.env.PLANET} and ${process.env.AUDIENCE}`);
});
পরিবেশগত ভেরিয়েবলের একাধিক সেট স্থাপন করা
আপনার Firebase প্রকল্পের জন্য যদি পরিবেশ ভেরিয়েবলের একটি বিকল্প সেটের প্রয়োজন হয় (যেমন স্টেজিং বনাম প্রোডাকশন), তাহলে একটি .env. <project or alias > ফাইল তৈরি করুন এবং সেখানে আপনার প্রকল্প-নির্দিষ্ট পরিবেশ ভেরিয়েবল লিখুন। .env এবং প্রকল্প-নির্দিষ্ট .env ফাইলের পরিবেশ ভেরিয়েবলগুলি (যদি থাকে) সমস্ত স্থাপন করা ফাংশনে অন্তর্ভুক্ত করা হবে।
উদাহরণস্বরূপ, একটি প্রকল্পে উন্নয়ন এবং উৎপাদনের জন্য সামান্য ভিন্ন মান সম্বলিত এই তিনটি ফাইল অন্তর্ভুক্ত থাকতে পারে:
.env | .env.dev | .env.prod |
| গ্রহ = পৃথিবী শ্রোতা = মানুষ | শ্রোতা=দেব মানুষ | শ্রোতা = উৎপাদিত মানুষ |
ঐ পৃথক ফাইলগুলির মানগুলি বিবেচনা করে, আপনার ফাংশনগুলির সাথে স্থাপন করা পরিবেশ ভেরিয়েবলের সেট আপনার লক্ষ্য প্রকল্পের উপর নির্ভর করে পরিবর্তিত হবে:
$ firebase use dev
$ firebase deploy --only functions
i functions: Loaded environment variables from .env, .env.dev.
# Deploys functions with following user-defined environment variables:
# PLANET=Earth
# AUDIENCE=Dev Humans
$ firebase use prod
$ firebase deploy --only functions
i functions: Loaded environment variables from .env, .env.prod.
# Deploys functions with following user-defined environment variables:
# PLANET=Earth
# AUDIENCE=Prod Humans
সংরক্ষিত পরিবেশ ভেরিয়েবল
কিছু এনভায়রনমেন্ট ভেরিয়েবল কী অভ্যন্তরীণ ব্যবহারের জন্য সংরক্ষিত। আপনার .env ফাইলগুলিতে এই কীগুলির কোনওটি ব্যবহার করবেন না:
- X_GOOGLE_ দিয়ে শুরু হওয়া সকল কী
- EXT_ থেকে শুরু হওয়া সকল কী
- FIREBASE_ দিয়ে শুরু হওয়া সকল কী
- নিম্নলিখিত তালিকা থেকে যেকোনো কী:
- ক্লাউড_রানটাইম_কনফিগ
- প্রবেশ_পয়েন্ট
- জিসিপি_প্রজেক্ট
- জিসিএলউড_প্রকল্প
- গুগল_ক্লাউড_প্রকল্প
- ফাংশন_ট্রিগার_টাইপ
- ফাংশন_নাম
- ফাংশন_মেমোরি_এমবি
- FUNCTION_TIMEOUT_SEC
- ফাংশন_আইডেন্টিটি
- ফাংশন_রিজিওন
- ফাংশন_টার্গেট
- ফাংশন_সিগন্যাচার_টাইপ
- কে_সার্ভিস
- K_REVISION সম্পর্কে
- বন্দর
- কে_কনফিগারেশন
সংবেদনশীল কনফিগারেশন তথ্য সংরক্ষণ এবং অ্যাক্সেস করুন
.env ফাইলে সংরক্ষিত পরিবেশ ভেরিয়েবলগুলি ফাংশন কনফিগারেশনের জন্য ব্যবহার করা যেতে পারে, তবে আপনার এগুলিকে ডেটাবেস শংসাপত্র বা API কীগুলির মতো সংবেদনশীল তথ্য সংরক্ষণের নিরাপদ উপায় হিসাবে বিবেচনা করা উচিত নয়। এটি বিশেষভাবে গুরুত্বপূর্ণ যদি আপনি আপনার .env ফাইলগুলিকে সোর্স নিয়ন্ত্রণে পরীক্ষা করেন।
সংবেদনশীল কনফিগারেশন তথ্য সংরক্ষণে আপনাকে সাহায্য করার জন্য, Cloud Functions for Firebase Google Cloud Secret Manager এর সাথে একীভূত হয়। এই এনক্রিপ্ট করা পরিষেবাটি কনফিগারেশন মানগুলিকে নিরাপদে সংরক্ষণ করে, একই সাথে প্রয়োজনে আপনার ফাংশনগুলি থেকে সহজে অ্যাক্সেসের অনুমতি দেয়।
একটি গোপন তথ্য তৈরি করুন এবং ব্যবহার করুন
একটি গোপন তথ্য তৈরি করতে, Firebase CLI ব্যবহার করুন।
একটি গোপন তথ্য তৈরি এবং ব্যবহার করতে:
আপনার স্থানীয় প্রকল্প ডিরেক্টরির মূল থেকে, নিম্নলিখিত কমান্ডটি চালান:
firebase functions:secrets:set SECRET_NAME
SECRET_NAME এর জন্য একটি মান লিখুন।
CLI একটি সাফল্যের বার্তা প্রতিধ্বনিত করে এবং সতর্ক করে যে পরিবর্তনটি কার্যকর করার জন্য আপনাকে অবশ্যই ফাংশন স্থাপন করতে হবে।
স্থাপনের আগে, নিশ্চিত করুন যে আপনার ফাংশন কোডটি
runWithপ্যারামিটার ব্যবহার করে ফাংশনটিকে গোপনীয়তা অ্যাক্সেস করার অনুমতি দেয়:exports.processPayment = functions // Make the secret available to this function .runWith({ secrets: ["SECRET_NAME"] }) .onCall((data, context) => { const myBillingService = initializeBillingService( // reference the secret value process.env.SECRET_NAME ); // Process the payment });Cloud Functions স্থাপন করুন:
firebase deploy --only functions
এখন আপনি অন্য যেকোনো এনভায়রনমেন্ট ভেরিয়েবলের মতো এটি অ্যাক্সেস করতে পারবেন। বিপরীতভাবে, যদি অন্য কোনও ফাংশন যা runWith এ গোপনীয়তা নির্দিষ্ট করে না, গোপনীয়তা অ্যাক্সেস করার চেষ্টা করে, তবে এটি একটি অনির্ধারিত মান পায়:
exports.anotherEndpoint = functions.https.onRequest((request, response) => {
response.send(`The secret API key is ${process.env.SECRET_NAME}`);
// responds with "The secret API key is undefined" because the `runWith` parameter is missing
});
একবার আপনার ফাংশনটি স্থাপন করা হয়ে গেলে, এটি গোপন মানটিতে অ্যাক্সেস পাবে। যে ফাংশনগুলি তাদের runWith প্যারামিটারে বিশেষভাবে একটি গোপন অন্তর্ভুক্ত করে কেবল তারাই পরিবেশ পরিবর্তনশীল হিসাবে সেই গোপনে অ্যাক্সেস পাবে। এটি আপনাকে নিশ্চিত করতে সাহায্য করে যে গোপন মানগুলি কেবল যেখানে প্রয়োজন সেখানেই উপলব্ধ, দুর্ঘটনাক্রমে কোনও গোপনীয়তা ফাঁস হওয়ার ঝুঁকি হ্রাস করে।
গোপনীয়তা পরিচালনা করা
আপনার গোপনীয়তা পরিচালনা করতে Firebase CLI ব্যবহার করুন। এইভাবে গোপনীয়তা পরিচালনা করার সময়, মনে রাখবেন যে কিছু CLI পরিবর্তনের জন্য আপনাকে সংশ্লিষ্ট ফাংশনগুলি পরিবর্তন এবং/অথবা পুনরায় স্থাপন করতে হবে। বিশেষ করে:
- যখনই আপনি কোনও গোপনীয়তার জন্য একটি নতুন মান সেট করবেন, তখন আপনাকে সেই গোপনীয়তার উল্লেখকারী সমস্ত ফাংশন পুনরায় স্থাপন করতে হবে যাতে তারা সর্বশেষ মানটি সংগ্রহ করতে পারে।
- যদি আপনি কোন গোপন তথ্য মুছে ফেলেন, তাহলে নিশ্চিত করুন যে আপনার স্থাপন করা কোনও ফাংশনই সেই গোপন তথ্য উল্লেখ করে না। যেসব ফাংশন মুছে ফেলা হয়েছে এমন গোপন মান ব্যবহার করে, সেগুলি নীরবে ব্যর্থ হবে।
গোপন ব্যবস্থাপনার জন্য Firebase সিএলআই কমান্ডের সারসংক্ষেপ এখানে দেওয়া হল:
# Change the value of an existing secret firebase functions:secrets:set SECRET_NAME # View the value of a secret functions:secrets:access SECRET_NAME # Destroy a secret functions:secrets:destroy SECRET_NAME # View all secret versions and their state functions:secrets:get SECRET_NAME # Automatically clean up all secrets that aren't referenced by any of your functions functions:secrets:prune
access এবং destroy কমান্ডের জন্য, আপনি একটি নির্দিষ্ট সংস্করণ পরিচালনা করার জন্য ঐচ্ছিক সংস্করণ প্যারামিটার প্রদান করতে পারেন। উদাহরণস্বরূপ:
functions:secrets:access SECRET_NAME[@VERSION]
এই ক্রিয়াকলাপগুলি সম্পর্কে আরও তথ্যের জন্য, CLI সহায়তা দেখার জন্য -h কমান্ডটি পাস করুন।
গোপন তথ্য কীভাবে জমা করা হয়
Secret Manager বিনামূল্যে ৬টি সক্রিয় গোপন সংস্করণের অনুমতি দেয়। এর মানে হল, আপনি একটি ফায়ারবেস প্রকল্পে প্রতি মাসে ৬টি গোপন সংস্করণ বিনামূল্যে রাখতে পারবেন।
ডিফল্টরূপে, Firebase CLI যখন উপযুক্ত হয় তখন অব্যবহৃত গোপন সংস্করণগুলি স্বয়ংক্রিয়ভাবে ধ্বংস করার চেষ্টা করে, যেমন যখন আপনি গোপনের একটি নতুন সংস্করণের সাথে ফাংশন স্থাপন করেন। এছাড়াও, আপনি functions:secrets:destroy এবং functions:secrets:prune ব্যবহার করে সক্রিয়ভাবে অব্যবহৃত গোপনীয়তাগুলি পরিষ্কার করতে পারেন।
Secret Manager একটি সিক্রেটে ১০,০০০টি বিলবিহীন মাসিক অ্যাক্সেস অপারেশনের অনুমতি দেয়। ফাংশন ইনস্ট্যান্সগুলি যখনই কোল্ড স্টার্ট করে তখন কেবল তাদের secrets অপশনে উল্লেখিত সিক্রেটগুলি পড়ে। যদি আপনার অনেক ফাংশন ইনস্ট্যান্স থাকে যা অনেক সিক্রেট পড়ে, তাহলে আপনার প্রকল্পটি এই ভাতা অতিক্রম করতে পারে, সেই সময়ে আপনাকে প্রতি ১০,০০০ অ্যাক্সেস অপারেশনের জন্য $০.০৩ চার্জ করা হবে।
আরও তথ্যের জন্য, Secret Manager প্রাইসিং দেখুন।
এমুলেটর সাপোর্ট
dotenv এর সাথে পরিবেশ কনফিগারেশনটি একটি স্থানীয় Cloud Functions এমুলেটরের সাথে ইন্টারঅপারেট করার জন্য ডিজাইন করা হয়েছে।
স্থানীয় Cloud Functions এমুলেটর ব্যবহার করার সময়, আপনি একটি .env.local ফাইল সেট আপ করে আপনার প্রকল্পের জন্য পরিবেশ ভেরিয়েবলগুলিকে ওভাররাইড করতে পারেন। .env.local এর বিষয়বস্তু .env এবং প্রকল্প-নির্দিষ্ট .env ফাইলের চেয়ে প্রাধান্য পায়।
উদাহরণস্বরূপ, একটি প্রকল্পে উন্নয়ন এবং স্থানীয় পরীক্ষার জন্য সামান্য ভিন্ন মান সম্বলিত এই তিনটি ফাইল অন্তর্ভুক্ত থাকতে পারে:
.env | .env.dev | .env.local |
| গ্রহ = পৃথিবী শ্রোতা = মানুষ | শ্রোতা=দেব মানুষ | শ্রোতা = স্থানীয় মানুষ |
স্থানীয় প্রসঙ্গে শুরু হলে, এমুলেটরটি পরিবেশের ভেরিয়েবলগুলি লোড করে যেমন দেখানো হয়েছে:
$ firebase emulators:start
i emulators: Starting emulators: functions
# Starts emulator with following environment variables:
# PLANET=Earth
# AUDIENCE=Local Humans
Cloud Functions এমুলেটরের গোপনীয়তা এবং শংসাপত্র
Cloud Functions এমুলেটর সংবেদনশীল কনফিগারেশন তথ্য সংরক্ষণ এবং অ্যাক্সেস করার জন্য সিক্রেট ব্যবহার সমর্থন করে। ডিফল্টরূপে, এমুলেটর অ্যাপ্লিকেশন ডিফল্ট শংসাপত্র ব্যবহার করে আপনার উৎপাদন সিক্রেট অ্যাক্সেস করার চেষ্টা করবে। CI পরিবেশের মতো কিছু পরিস্থিতিতে, অনুমতি সীমাবদ্ধতার কারণে এমুলেটর গোপন মান অ্যাক্সেস করতে ব্যর্থ হতে পারে।
পরিবেশ ভেরিয়েবলের জন্য Cloud Functions এমুলেটর সাপোর্টের মতো, আপনি একটি .secret.local ফাইল সেট আপ করে গোপন মানগুলিকে ওভাররাইড করতে পারেন। এটি আপনার জন্য স্থানীয়ভাবে আপনার ফাংশনগুলি পরীক্ষা করা সহজ করে তোলে, বিশেষ করে যদি আপনার গোপন মানটিতে অ্যাক্সেস না থাকে।
রানটাইম কনফিগারেশন থেকে মাইগ্রেট করুন
যদি আপনি functions.config দিয়ে পরিবেশ কনফিগারেশন ব্যবহার করে থাকেন, তাহলে ২০২৫ সালের শেষের আগে আপনার বিদ্যমান কনফিগারেশনটি একটি সমর্থিত ফর্ম্যাটে স্থানান্তর করতে হবে, যখন functions.config বাতিল করা হবে। ২০২৫ সালের ডিসেম্বরের পরে, functions.config দিয়ে নতুন স্থাপনা ব্যর্থ হবে।
বেশিরভাগ ব্যবহারের ক্ষেত্রে, প্যারামিটারাইজড কনফিগারেশন সুপারিশ করা হয়। এই পদ্ধতিটি রানটাইম এবং ডিপ্লয় সময় উভয় সময়েই কনফিগারেশন মান উপলব্ধ করে এবং সমস্ত প্যারামিটারের একটি বৈধ মান না থাকলে ডিপ্লয়মেন্ট ব্লক করা হয়।
params সাবপ্যাকেজে মাইগ্রেট করুন
যদি আপনি functions.config দিয়ে পরিবেশ কনফিগারেশন ব্যবহার করে থাকেন, তাহলে আপনি আপনার বিদ্যমান কনফিগারেশনটিকে প্যারামিটারাইজড কনফিগারেশন হিসাবে রিফ্যাক্টর করে স্থানান্তর করতে পারেন। উদাহরণস্বরূপ:
আগে: ১ম প্রজন্ম
const functions = require("firebase-functions/v1");
exports.date = functions.https.onRequest((req, res) => {
const date = new Date();
const formattedDate =
date.toLocaleDateString(functions.config().dateformat);
// ...
});
পরে: দ্বিতীয় প্রজন্ম
const {onRequest} = require("firebase-functions/v2/https");
const {defineString} = require("firebase-functions/params");
const dateFormat = defineString("DATE_FORMAT");
exports.date = onRequest((req, res) => {
const date = new Date();
const formattedDate = date.toLocaleDateString(dateFormat.value());
// ...
});
প্যারামিটারের মান সেট করুন
প্রথমবার যখন আপনি স্থাপন করবেন, তখন Firebase CLI সমস্ত প্যারামিটারের মান জিজ্ঞাসা করবে এবং মানগুলি একটি dotenv ফাইলে সংরক্ষণ করবে। আপনার functions.config মানগুলি রপ্তানি করতে, firebase functions:config:export চালান।
অতিরিক্ত নিরাপত্তার জন্য, আপনি প্যারামিটারের ধরন এবং বৈধতা নিয়মও নির্দিষ্ট করতে পারেন।
বিশেষ ক্ষেত্রে: API কী
params মডিউলটি ক্লাউড সিক্রেট ম্যানেজারের সাথে একীভূত হয়, যা API কীগুলির মতো সংবেদনশীল মানগুলিতে সূক্ষ্ম অ্যাক্সেস নিয়ন্ত্রণ প্রদান করে। আরও তথ্যের জন্য গোপন প্যারামিটারগুলি দেখুন।
স্বয়ংক্রিয়ভাবে জনবহুল পরিবেশ ভেরিয়েবল
কিছু এনভায়রনমেন্ট ভেরিয়েবল আছে যা স্বয়ংক্রিয়ভাবে ফাংশন রানটাইম এবং স্থানীয়ভাবে অনুকরণ করা ফাংশনে পূর্ণ হয়। এর মধ্যে রয়েছে Google Cloud দ্বারা পূর্ণ করা ভেরিয়েবল , সেইসাথে একটি Firebase-নির্দিষ্ট পরিবেশ ভেরিয়েবল:
process.env.FIREBASE_CONFIG : নিম্নলিখিত Firebase প্রকল্প কনফিগারেশন তথ্য প্রদান করে:
{
databaseURL: 'https://DATABASE_NAME.firebaseio.com',
storageBucket: 'PROJECT_ID.firebasestorage.app ',
projectId: 'PROJECT_ID'
}
মনে রাখবেন যে আপনার প্রকৃত Firebase কনফিগারেশনের মানগুলি আপনার প্রকল্পে প্রয়োগ করা রিসোর্সের উপর নির্ভর করে পরিবর্তিত হতে পারে।
কোনও আর্গুমেন্ট ছাড়াই Firebase Admin SDK চালু করলে এই কনফিগারেশনটি স্বয়ংক্রিয়ভাবে প্রয়োগ করা হয়। যদি আপনি জাভাস্ক্রিপ্টে ফাংশন লিখছেন, তাহলে এভাবে শুরু করুন:
const admin = require('firebase-admin');
admin.initializeApp();
যদি আপনি টাইপস্ক্রিপ্টে ফাংশন লিখছেন, তাহলে এভাবে শুরু করুন:
import * as functions from 'firebase-functions/v1';
import * as admin from 'firebase-admin';
import 'firebase-functions/v1';
admin.initializeApp();
যদি আপনার সার্ভিস অ্যাকাউন্ট ক্রেডেনশিয়াল ব্যবহার করে ডিফল্ট প্রজেক্ট কনফিগারেশনের মাধ্যমে অ্যাডমিন SDK আরম্ভ করার প্রয়োজন হয়, তাহলে আপনি একটি ফাইল থেকে ক্রেডেনশিয়াল লোড করতে পারেন এবং FIREBASE_CONFIG এ এভাবে যোগ করতে পারেন:
serviceAccount = require('./serviceAccount.json');
const adminConfig = JSON.parse(process.env.FIREBASE_CONFIG);
adminConfig.credential = admin.credential.cert(serviceAccount);
admin.initializeApp(adminConfig);