Firebase সিএলআই ( গিটহাব ) ফায়ারবেস প্রজেক্ট পরিচালনা, দেখা এবং ডেপ্লয় করার জন্য বিভিন্ন ধরনের টুল সরবরাহ করে।
Before using the Firebase CLI, set up a Firebase project .
CLI সেট আপ বা আপডেট করুন
Firebase CLI ইনস্টল করুন
আপনি আপনার অপারেটিং সিস্টেম, অভিজ্ঞতার স্তর এবং/অথবা ব্যবহারের ধরনের সাথে সামঞ্জস্যপূর্ণ একটি পদ্ধতি ব্যবহার করে Firebase সিএলআই ইনস্টল করতে পারেন। আপনি যেভাবে সিএলআই ইনস্টল করুন না কেন, আপনি একই কার্যকারিতা এবং firebase কমান্ডটি ব্যবহার করতে পারবেন।
উইন্ডোজ
আপনি নিম্নলিখিত বিকল্পগুলির মধ্যে যেকোনো একটি ব্যবহার করে উইন্ডোজের জন্য Firebase সিএলআই ইনস্টল করতে পারেন:
| বিকল্প | বর্ণনা | এর জন্য প্রস্তাবিত... |
|---|---|---|
| স্বতন্ত্র বাইনারি | Download the standalone binary for the CLI. Then, you can access the executable to open a shell where you can run the firebase command. | নতুন ডেভেলপাররা যেসব ডেভেলপার Node.js ব্যবহার করেন না বা এর সাথে পরিচিত নন |
| এনপিএম | npm (নোড প্যাকেজ ম্যানেজার) ব্যবহার করে CLI ইনস্টল করুন এবং বিশ্বব্যাপী উপলব্ধ firebase কমান্ডটি সক্রিয় করুন। | Node.js ব্যবহারকারী ডেভেলপাররা |
স্বতন্ত্র বাইনারি
To download and run the binary for the Firebase CLI, follow these steps:
উইন্ডোজের জন্য Firebase সিএলআই বাইনারি ডাউনলোড করুন।
একটি শেল খোলার জন্য বাইনারিটি অ্যাক্সেস করুন, যেখানে আপনি
firebaseকমান্ডটি চালাতে পারবেন।লগ ইন করে CLI পরীক্ষা করা চালিয়ে যান।
এনপিএম
To use npm (the Node Package Manager) to install the Firebase CLI, follow these steps:
Install Node.js using nvm-windows (the Node Version Manager). Installing Node.js automatically installs the
npmcommand tools.Install the Firebase CLI via
npmby running the following command:npm install -g firebase-tools
This command enables the globally available
firebasecommand.লগ ইন করে CLI পরীক্ষা করা চালিয়ে যান।
ম্যাকওএস বা লিনাক্স
আপনি নিচের যেকোনো একটি বিকল্প ব্যবহার করে macOS বা Linux-এর জন্য Firebase CLI ইনস্টল করতে পারেন:
| বিকল্প | বর্ণনা | এর জন্য প্রস্তাবিত... |
|---|---|---|
| স্বয়ংক্রিয় ইনস্টল স্ক্রিপ্ট | Run a single command that automatically detects your operating system, downloads the latest CLI release, then enables the globally available firebase command. | নতুন ডেভেলপাররা যেসব ডেভেলপার Node.js ব্যবহার করেন না বা এর সাথে পরিচিত নন CI/CD পরিবেশে স্বয়ংক্রিয় ডেপ্লয় |
| স্বতন্ত্র বাইনারি | Download the standalone binary for the CLI. Then, you can configure and run the binary to suit your workflow. | CLI ব্যবহার করে সম্পূর্ণরূপে কাস্টমাইজযোগ্য ওয়ার্কফ্লো |
| এনপিএম | npm (নোড প্যাকেজ ম্যানেজার) ব্যবহার করে CLI ইনস্টল করুন এবং বিশ্বব্যাপী উপলব্ধ firebase কমান্ডটি সক্রিয় করুন। | Node.js ব্যবহারকারী ডেভেলপাররা |
স্বয়ংক্রিয় ইনস্টল স্ক্রিপ্ট
To install the Firebase CLI using the automatic install script, follow these steps:
নিম্নলিখিত cURL কমান্ডটি চালান:
curl -sL https://firebase.tools | bash
This script automatically detects your operating system, downloads the latest Firebase CLI release, then enables the globally available
firebasecommand.লগ ইন করে CLI পরীক্ষা করা চালিয়ে যান।
For more examples and details about the automatic install script, refer to the script's source code at firebase.tools .
স্বতন্ত্র বাইনারি
আপনার অপারেটিং সিস্টেমের জন্য নির্দিষ্ট Firebase CLI বাইনারিটি ডাউনলোড ও রান করতে, এই ধাপগুলো অনুসরণ করুন:
(ঐচ্ছিক) বিশ্বব্যাপী উপলব্ধ
firebaseকমান্ডটি সেট আপ করুন।-
chmod +x ./firebase_toolsকমান্ডটি চালিয়ে বাইনারিটিকে এক্সিকিউটেবল করুন। - বাইনারিটির পাথ আপনার PATH-এ যোগ করুন।
-
লগ ইন করে CLI পরীক্ষা করা চালিয়ে যান।
এনপিএম
To use npm (the Node Package Manager) to install the Firebase CLI, follow these steps:
nvm (নোড ভার্সন ম্যানেজার) ব্যবহার করে Node.js ইনস্টল করুন।
Node.js ইনস্টল করলে স্বয়ংক্রিয়ভাবেnpmকমান্ড টুলগুলোও ইনস্টল হয়ে যায়।Install the Firebase CLI via
npmby running the following command:npm install -g firebase-tools
এই কমান্ডটি বিশ্বব্যাপী উপলব্ধ
firebaseকমান্ডটি সক্রিয় করে।লগ ইন করে CLI পরীক্ষা করা চালিয়ে যান।
লগ ইন করুন এবং Firebase CLI পরীক্ষা করুন
CLI ইনস্টল করার পর আপনাকে অবশ্যই প্রমাণীকরণ করতে হবে। তারপর আপনার Firebase প্রজেক্টগুলো তালিকাভুক্ত করে আপনি প্রমাণীকরণ নিশ্চিত করতে পারবেন।
Log into Firebase using your Google account by running the following command:
firebase login
এই কমান্ডটি আপনার লোকাল মেশিনকে ফায়ারবেসের সাথে সংযুক্ত করে এবং আপনাকে আপনার ফায়ারবেস প্রজেক্টগুলোতে অ্যাক্সেস প্রদান করে।
Test that the CLI is properly installed and accessing your account by listing your Firebase projects. Run the following command:
firebase projects:list
The displayed list should be the same as the Firebase projects listed in the Firebase console .
সর্বশেষ CLI সংস্করণে আপডেট করুন
Generally, you want to use the most up-to-date Firebase CLI version.
How you update the CLI version depends on your operating system and how you installed the CLI.
উইন্ডোজ
- standalone binary : Download the new version , then replace it on your system
- npm :
npm install -g firebase-toolsচালান
ম্যাকওএস
স্বয়ংক্রিয় ইনস্টল স্ক্রিপ্ট :
curl -sL https://firebase.tools | upgrade=true bashচালানstandalone binary : Download the new version , then replace it on your system
npm :
npm install -g firebase-toolsচালান
লিনাক্স
স্বয়ংক্রিয় ইনস্টল স্ক্রিপ্ট :
curl -sL https://firebase.tools | upgrade=true bashচালানস্বতন্ত্র বাইনারি : নতুন সংস্করণটি ডাউনলোড করুন , তারপর আপনার সিস্টেমে এটি প্রতিস্থাপন করুন।
npm :
npm install -g firebase-toolsচালান
Firebase CLI আনইনস্টল করুন
আপনি কীভাবে CLI আনইনস্টল করবেন তা আপনার অপারেটিং সিস্টেম এবং আপনি কীভাবে CLI ইনস্টল করেছেন তার উপর নির্ভর করে।
উইন্ডোজ
- স্বতন্ত্র বাইনারি : আপনার ডাউনলোড করা
firebase.exeবাইনারিটি মুছে ফেলুন। - npm :
npm uninstall -g firebase-toolsচালান
ম্যাকওএস
automatic install script : Run
curl -sL https://firebase.tools | uninstall=true bashstandalone binary : Delete the
firebasebinary that you downloaded. If you added its location to yourPATHenvironment variable, be sure to remove it.npm :
npm uninstall -g firebase-toolsচালান
লিনাক্স
স্বয়ংক্রিয় ইনস্টল স্ক্রিপ্ট :
curl -sL https://firebase.tools | uninstall=true bashচালানস্বতন্ত্র বাইনারি : আপনার ডাউনলোড করা
firebaseবাইনারিটি মুছে ফেলুন। যদি আপনি এটির অবস্থান আপনারPATHএনভায়রনমেন্ট ভেরিয়েবলে যোগ করে থাকেন, তবে অবশ্যই তা সরিয়ে ফেলুন।npm :
npm uninstall -g firebase-toolsচালান
CI সিস্টেমের সাথে CLI ব্যবহার করুন
CI সিস্টেমের সাথে CLI ব্যবহার করার সময় আমরা আপনাকে অ্যাপ্লিকেশন ডিফল্ট ক্রেডেনশিয়াল ব্যবহার করে প্রমাণীকরণের পরামর্শ দিই।
(Recommended) Use Application Default Credentials
অ্যাপ্লিকেশন ডিফল্ট ক্রেডেনশিয়াল সেট করা থাকলে Firebase CLI তা শনাক্ত করে ব্যবহার করবে। CI এবং অন্যান্য হেডলেস পরিবেশে CLI-কে অথেন্টিকেট করার সবচেয়ে সহজ উপায় হলো অ্যাপ্লিকেশন ডিফল্ট ক্রেডেনশিয়াল সেট আপ করা ।
(লেগ্যাসি) FIREBASE_TOKEN ব্যবহার করুন
বিকল্পভাবে, আপনি FIREBASE_TOKEN ব্যবহার করে প্রমাণীকরণ করতে পারেন। এটি অ্যাপ্লিকেশন ডিফল্ট ক্রেডেনশিয়াল-এর চেয়ে কম সুরক্ষিত এবং এখন আর এর সুপারিশ করা হয় না।
ব্রাউজারযুক্ত কোনো মেশিনে Firebase CLI ইনস্টল করুন ।
নিম্নলিখিত কমান্ডটি চালিয়ে সাইন-ইন প্রক্রিয়া শুরু করুন:
firebase login:ci
প্রদত্ত ইউআরএল-এ যান, তারপর একটি গুগল অ্যাকাউন্ট ব্যবহার করে লগ ইন করুন।
একটি নতুন রিফ্রেশ টোকেন প্রিন্ট করুন। বর্তমান CLI সেশনটি প্রভাবিত হবে না।
আপনার CI সিস্টেমে আউটপুট টোকেনটি একটি সুরক্ষিত কিন্তু অ্যাক্সেসযোগ্য উপায়ে সংরক্ষণ করুন।
firebaseকমান্ড চালানোর সময় এই টোকেনটি ব্যবহার করুন। আপনি নিম্নলিখিত দুটি বিকল্পের যেকোনো একটি ব্যবহার করতে পারেন:বিকল্প ১: টোকেনটি
FIREBASE_TOKENএনভায়রনমেন্ট ভেরিয়েবল হিসেবে সংরক্ষণ করুন। আপনার সিস্টেম স্বয়ংক্রিয়ভাবে টোকেনটি ব্যবহার করবে।বিকল্প ২: আপনার CI সিস্টেমে সমস্ত
firebaseকমান্ড--token TOKENফ্ল্যাগ সহ চালান।
টোকেন লোড করার ক্ষেত্রে অগ্রাধিকারের ক্রমটি হলো: ফ্ল্যাগ, এনভায়রনমেন্ট ভেরিয়েবল, কাঙ্ক্ষিত ফায়ারবেস প্রজেক্ট।
একটি ফায়ারবেস প্রজেক্ট শুরু করুন
CLI ব্যবহার করে করা অনেক সাধারণ কাজ, যেমন একটি ফায়ারবেস প্রজেক্টে ডিপ্লয় করা, একটি প্রজেক্ট ডিরেক্টরির প্রয়োজন হয়। আপনি firebase init কমান্ড ব্যবহার করে একটি প্রজেক্ট ডিরেক্টরি তৈরি করেন। একটি প্রজেক্ট ডিরেক্টরি সাধারণত আপনার সোর্স কন্ট্রোল রুটের মতোই হয়, এবং firebase init চালানোর পরে, সেই ডিরেক্টরিতে একটি firebase.json কনফিগারেশন ফাইল থাকে।
একটি নতুন Firebase প্রজেক্ট শুরু করতে, আপনার অ্যাপের ডিরেক্টরির ভেতর থেকে নিম্নলিখিত কমান্ডটি চালান:
firebase init
firebase init কমান্ডটি আপনাকে আপনার প্রজেক্ট ডিরেক্টরি এবং কিছু ফায়ারবেস প্রোডাক্ট সেট আপ করার প্রক্রিয়াটি ধাপে ধাপে দেখিয়ে দেয়। প্রজেক্ট ইনিশিয়ালাইজেশনের সময়, Firebase সিএলআই আপনাকে নিম্নলিখিত কাজগুলো সম্পন্ন করতে বলে:
একটি ডিফল্ট ফায়ারবেস প্রজেক্ট নির্বাচন করুন।
এই ধাপে বর্তমান প্রজেক্ট ডিরেক্টরিকে একটি ফায়ারবেস প্রজেক্টের সাথে যুক্ত করা হয়, যাতে প্রজেক্ট-নির্দিষ্ট কমান্ডগুলো (যেমন
firebase deploy) সঠিক ফায়ারবেস প্রজেক্টে রান হয়।এছাড়াও একাধিক ফায়ারবেস প্রজেক্ট (যেমন একটি স্টেজিং প্রজেক্ট এবং একটি প্রোডাকশন প্রজেক্ট) একই প্রজেক্ট ডিরেক্টরির সাথে যুক্ত করা সম্ভব।
আপনার ফায়ারবেস প্রজেক্টে সেট আপ করার জন্য ফায়ারবেস প্রোডাক্টগুলো নির্বাচন করুন।
এই ধাপে আপনাকে নির্বাচিত প্রোডাক্ট বা ফিচারগুলোর জন্য নির্দিষ্ট ফাইলগুলোর কনফিগারেশন সেট করতে বলা হবে। এই কনফিগারেশনগুলো সম্পর্কে আরও বিস্তারিত জানতে, নির্দিষ্ট প্রোডাক্টের ডকুমেন্টেশন দেখুন (যেমন, Hosting বা Authentication )। মনে রাখবেন, আপনি পরবর্তীতে আরও ফায়ারবেস প্রোডাক্ট সেট আপ করার জন্য যেকোনো সময়
firebase initচালাতে পারেন।
প্রারম্ভিককরণের শেষে, Firebase স্বয়ংক্রিয়ভাবে আপনার স্থানীয় অ্যাপ ডিরেক্টরির রুটে নিম্নলিখিত দুটি ফাইল তৈরি করে:
firebase.jsonকনফিগারেশন ফাইল, যেখানে আপনার প্রোজেক্টের কনফিগারেশন তালিকাভুক্ত থাকে।একটি
.firebasercফাইল যা আপনার প্রোজেক্টের অ্যালিয়াসগুলো সংরক্ষণ করে।
firebase.json ফাইল
firebase init কমান্ডটি আপনার প্রজেক্ট ডিরেক্টরির রুটে একটি firebase.json কনফিগারেশন ফাইল তৈরি করে।
Firebase CLI ব্যবহার করে অ্যাসেট ডেপ্লয় করার জন্য firebase.json ফাইলটি প্রয়োজন, কারণ এটি নির্দিষ্ট করে দেয় যে আপনার প্রজেক্ট ডিরেক্টরি থেকে কোন ফাইল এবং সেটিংস আপনার Firebase প্রজেক্টে ডেপ্লয় করা হবে (যেমন Hosting সেটিংস, Authentication প্রোভাইডার কনফিগারেশন, সিকিউরিটি রুলস এবং Cloud Functions কনফিগারেশন)। যেহেতু কিছু সেটিংস আপনার প্রজেক্ট ডিরেক্টরি অথবা Firebase কনসোল উভয় স্থানেই নির্ধারণ করা যায়, তাই ডেপ্লয়মেন্ট সংক্রান্ত যেকোনো সম্ভাব্য দ্বন্দ্ব সমাধান করে নেওয়া নিশ্চিত করুন।
আপনি বেশিরভাগ Firebase Hosting অপশন সরাসরি firebase.json ফাইলে কনফিগার করতে পারেন। তবে, অন্যান্য ফায়ারবেস সার্ভিসগুলোর জন্য যেগুলো Firebase CLI দিয়ে ডেপ্লয় করা যায় , firebase init কমান্ডটি নির্দিষ্ট ফাইল তৈরি করে যেখানে আপনি সেই সার্ভিসগুলোর জন্য সেটিংস নির্ধারণ করতে পারেন, যেমন Cloud Functions জন্য একটি index.js ফাইল। এছাড়াও আপনি firebase.json ফাইলে প্রি-ডেপ্লয় বা পোস্ট-ডেপ্লয় হুক সেট আপ করতে পারেন।
নিম্নলিখিত firebase.json ফাইলটি অনেক Firebase পরিষেবার কনফিগারেশন বিকল্পগুলি প্রদর্শনকারী একটি বিশদ উদাহরণ। এটি মাল্টি-কোডবেস Cloud Functions , Local Emulator Suite সেটআপ এবং একটি Remote Config টেমপ্লেটের মতো বৈশিষ্ট্যগুলিও প্রদর্শন করে। মনে রাখবেন যে, যেকোনো নির্দিষ্ট প্রকল্পের firebase.json ফাইলে শুধুমাত্র সেই প্রকল্পের জন্য সেট আপ করা Firebase পরিষেবাগুলির কনফিগারেশন থাকবে (উদাহরণস্বরূপ, শুধুমাত্র Firebase Hosting এবং Cloud Functions )। $schema কী যোগ করলে অনেক কোড এডিটরে ভ্যালিডেশন এবং অটোকমপ্লিশন সক্ষম হয়।
{
"$schema": "https://raw.githubusercontent.com/firebase/firebase-tools/master/schema/firebase-config.json",
"hosting": {
"public": "public",
"ignore": [
"firebase.json",
"**/.*",
"**/node_modules/**"
],
"cleanUrls": true,
"trailingSlash": false
},
"apphosting": {
"backendId": "my-app",
"rootDir": "backend",
"ignore": [
"firebase.json",
"**/.*",
"**/node_modules/**"
]
},
"firestore": {
"rules": "firestore.rules",
"indexes": "firestore.indexes.json"
},
"storage": {
"rules": "storage.rules"
},
"database": {
"rules": "database.rules.json"
},
"dataconnect": {
"source": "dataconnect",
"location": "us-central1"
},
"functions": [
{
"source": "functions",
"codebase": "default",
"ignore": [
"**/.*",
"**/node_modules/**"
],
"predeploy": [
"npm --prefix \"$RESOURCE_DIR\" run lint",
"npm --prefix \"$RESOURCE_DIR\" run build"
]
}
],
"emulators": {
"auth": {
"port": 9099
},
"functions": {
"port": 5001
},
"firestore": {
"port": 8080
},
"hosting": {
"port": 5000
},
"storage": {
"port": 9199
},
"ui": {
"enabled": true,
"port": 4000
},
"singleProjectMode": true
},
"extensions": {
"my-storage-resizer": "firebase/storage-resize-images@^0.1.0"
},
"auth": {
"providers": {
"anonymous": true,
"emailPassword": true,
"googleSignIn": {
"oAuthBrandDisplayName": "My App",
"supportEmail": "support@myapp.com"
}
}
},
"remoteconfig": {
"template": "remoteconfig.template.json"
}
}
ডিফল্টরূপে firebase.json ব্যবহৃত হলেও, আপনি --config PATH ফ্ল্যাগটি ব্যবহার করে একটি বিকল্প কনফিগারেশন ফাইল নির্দিষ্ট করতে পারেন।
একাধিক Cloud Firestore ডেটাবেসের জন্য কনফিগারেশন
যখন আপনি firebase init চালাবেন, তখন আপনার firebase.json ফাইলে আপনার প্রোজেক্টের ডিফল্ট ডেটাবেসের সাথে সম্পর্কিত একটিমাত্র firestore কী থাকবে, যেমনটি পূর্ববর্তী উদাহরণে দেখানো হয়েছে।
আপনার প্রজেক্টে একাধিক Cloud Firestore ডেটাবেস থাকলে, প্রতিটি ডেটাবেসের সাথে আলাদা Cloud Firestore Security Rules এবং ডেটাবেস ইনডেক্স সোর্স ফাইল যুক্ত করতে আপনার firebase.json ফাইলটি সম্পাদনা করুন। ফাইলটি একটি JSON অ্যারে দিয়ে পরিবর্তন করুন, যেখানে প্রতিটি ডেটাবেসের জন্য একটি করে এন্ট্রি থাকবে।
"firestore": [
{
"database": "(default)",
"rules": "firestore.default.rules",
"indexes": "firestore.default.indexes.json"
},
{
"database": "ecommerce",
"rules": "firestore.ecommerce.rules",
"indexes": "firestore.ecommerce.indexes.json"
}
],
ডিপ্লয় করার সময় উপেক্ষা করার জন্য Cloud Functions ফাইল
ফাংশন ডেপ্লয়মেন্টের সময়, CLI স্বয়ংক্রিয়ভাবে functions ডিরেক্টরিতে উপেক্ষা করার জন্য ফাইলগুলির একটি তালিকা নির্দিষ্ট করে দেয়। এর ফলে ব্যাকএন্ডে এমন অপ্রয়োজনীয় ফাইল ডেপ্লয় হওয়া থেকে বিরত থাকা যায়, যা আপনার ডেপ্লয়মেন্টের ডেটার আকার বাড়িয়ে দিতে পারে।
ডিফল্টরূপে উপেক্ষা করা ফাইলগুলির তালিকা, যা JSON ফরম্যাটে দেখানো হয়েছে, তা হলো:
"ignore": [
".git",
".runtimeconfig.json",
"firebase-debug.log",
"firebase-debug.*.log",
"node_modules"
]
আপনি যদি firebase.json এ ignore এর জন্য আপনার নিজস্ব কাস্টম মান যোগ করেন, তাহলে নিশ্চিত করুন যে আপনি পূর্ববর্তী তালিকায় দেখানো ফাইলগুলির তালিকাটি রেখেছেন (অথবা অনুপস্থিত থাকলে যোগ করেছেন)।
প্রকল্পের বিকল্প নামগুলি পরিচালনা করুন
আপনি একই প্রজেক্ট ডিরেক্টরির সাথে একাধিক ফায়ারবেস প্রজেক্ট যুক্ত করতে পারেন। উদাহরণস্বরূপ, আপনি স্টেজিংয়ের জন্য একটি ফায়ারবেস প্রজেক্ট এবং প্রোডাকশনের জন্য অন্যটি ব্যবহার করতে চাইতে পারেন। ভিন্ন ভিন্ন প্রজেক্ট এনভায়রনমেন্ট ব্যবহার করে, আপনি প্রোডাকশনে ডেপ্লয় করার আগে পরিবর্তনগুলো যাচাই করে নিতে পারেন। firebase use কমান্ডটি আপনাকে অ্যালিয়াসগুলোর মধ্যে পরিবর্তন করার পাশাপাশি নতুন অ্যালিয়াস তৈরি করতেও সাহায্য করে।
একটি প্রজেক্ট উপনাম যোগ করুন
প্রজেক্ট ইনিশিয়ালাইজেশনের সময় আপনি যখন একটি ফায়ারবেস প্রজেক্ট নির্বাচন করেন, তখন প্রজেক্টটিকে স্বয়ংক্রিয়ভাবে ' default ' অ্যালিয়াসটি দেওয়া হয়। তবে, একই প্রজেক্ট ডিরেক্টরি ব্যবহার করে অন্য কোনো ফায়ারবেস প্রজেক্টে প্রজেক্ট-নির্দিষ্ট কমান্ড চালানোর অনুমতি দিতে, আপনার প্রজেক্ট ডিরেক্টরির ভেতর থেকে নিম্নলিখিত কমান্ডটি চালান:
firebase use --add
এই কমান্ডটি আপনাকে অন্য একটি ফায়ারবেস প্রজেক্ট নির্বাচন করতে এবং সেটিকে অ্যালিয়াস হিসেবে নির্ধারণ করতে বলে। অ্যালিয়াস নির্ধারণগুলো আপনার প্রজেক্ট ডিরেক্টরির ভেতরে একটি .firebaserc ফাইলে লেখা হয়।
প্রকল্পের বিকল্প নাম ব্যবহার করুন
নির্ধারিত ফায়ারবেস প্রজেক্ট অ্যালিয়াস ব্যবহার করতে, আপনার প্রজেক্ট ডিরেক্টরির ভেতর থেকে নিচের যেকোনো একটি কমান্ড চালান।
| আদেশ | বর্ণনা |
|---|---|
firebase use | আপনার প্রজেক্ট ডিরেক্টরির জন্য সংজ্ঞায়িত উপনামগুলির তালিকা দেখুন |
firebase use \ | সমস্ত কমান্ড নির্দিষ্ট ফায়ারবেস প্রজেক্টের বিপরীতে চালানোর নির্দেশ দেয়। CLI এই প্রজেক্টটিকে 'সক্রিয় প্রজেক্ট' হিসেবে ব্যবহার করে। |
firebase use --clear | সক্রিয় প্রকল্পটি মুছে ফেলে। অন্যান্য CLI কমান্ড চালানোর আগে একটি নতুন সক্রিয় প্রজেক্ট সেট করতে |
firebase use \ | আপনার প্রজেক্ট ডিরেক্টরি থেকে একটি অ্যালিয়াস মুছে ফেলে। |
যেকোনো CLI কমান্ডের সাথে --project ফ্ল্যাগটি পাস করে আপনি সক্রিয় প্রজেক্ট হিসেবে ব্যবহৃত হওয়াকে ওভাররাইড করতে পারেন। উদাহরণস্বরূপ: আপনি আপনার CLI-কে এমন একটি Firebase প্রজেক্টের বিরুদ্ধে চালানোর জন্য সেট করতে পারেন, যেটিকে আপনি staging অ্যালিয়াস দিয়েছেন। যদি আপনি সেই Firebase প্রজেক্টের বিরুদ্ধে একটিমাত্র কমান্ড চালাতে চান যেটিকে আপনি prod অ্যালিয়াস দিয়েছেন, তাহলে আপনি চালাতে পারেন, যেমন, ।
উৎস নিয়ন্ত্রণ এবং প্রকল্পের বিকল্প নাম
সাধারণত, আপনার টিমকে প্রোজেক্ট অ্যালিয়াস শেয়ার করার সুযোগ দিতে আপনার .firebaserc ফাইলটি সোর্স কন্ট্রোলে চেক ইন করা উচিত। তবে, ওপেন সোর্স প্রোজেক্ট বা স্টার্টার টেমপ্লেটের ক্ষেত্রে সাধারণত আপনার .firebaserc ফাইলটি চেক ইন করা উচিত নয়।
আপনার যদি শুধুমাত্র আপনার ব্যবহারের জন্য কোনো ডেভেলপমেন্ট প্রজেক্ট থাকে, তাহলে আপনি প্রতিটি কমান্ডের সাথে --project ফ্ল্যাগটি পাস করতে পারেন অথবা ফায়ারবেস প্রজেক্টে কোনো অ্যালিয়াস নির্ধারণ না করেই firebase use PROJECT_ID চালাতে পারেন।
আপনার ফায়ারবেস প্রজেক্ট স্থানীয়ভাবে পরিবেশন ও পরীক্ষা করুন
প্রোডাকশনে ডেপ্লয় করার আগে আপনি আপনার ফায়ারবেস প্রজেক্টটি স্থানীয়ভাবে হোস্ট করা ইউআরএল-এ দেখতে ও পরীক্ষা করতে পারেন। যদি আপনি শুধু নির্দিষ্ট কিছু ফিচার পরীক্ষা করতে চান, তাহলে firebase serve কমান্ডের ফ্ল্যাগে কমা দিয়ে আলাদা করা একটি তালিকা ব্যবহার করতে পারেন।
আপনি যদি নিম্নলিখিত কাজগুলোর মধ্যে কোনো একটি করতে চান, তাহলে আপনার স্থানীয় প্রজেক্ট ডিরেক্টরির রুট থেকে নিম্নলিখিত কমান্ডটি চালান:
- আপনার ফায়ারবেস-হোস্টেড অ্যাপের স্ট্যাটিক কন্টেন্ট দেখুন।
- Firebase Hosting জন্য ডায়নামিক কন্টেন্ট তৈরি করতে Cloud Functions ব্যবহার করুন এবং একটি লোকাল ইউআরএল-এ Hosting অনুকরণ করতে আপনার প্রোডাকশন (ডিপ্লয় করা) HTTP ফাংশনগুলো ব্যবহার করতে চান।
firebase serve --only hosting
স্থানীয় HTTP ফাংশন ব্যবহার করে আপনার প্রজেক্টটি অনুকরণ করুন
স্থানীয় HTTP ফাংশন ব্যবহার করে আপনার প্রজেক্ট অনুকরণ করতে, আপনার প্রজেক্ট ডিরেক্টরি থেকে নিম্নলিখিত কমান্ডগুলোর যেকোনো একটি চালান।
স্থানীয় ইউআরএল-এ পরীক্ষার জন্য এইচটিটিপি ফাংশন ও হোস্টিং অনুকরণ করতে, নিচের কমান্ডগুলোর যেকোনো একটি ব্যবহার করুন:
firebase serve
firebase serve --only functions,hosting // uses a flag
শুধুমাত্র HTTP ফাংশন অনুকরণ করতে, নিম্নলিখিত কমান্ডটি ব্যবহার করুন:
firebase serve --only functions
অন্যান্য স্থানীয় ডিভাইস থেকে পরীক্ষা করুন
ডিফল্টরূপে, firebase serve শুধুমাত্র localhost থেকে আসা অনুরোধে সাড়া দেয়। এর মানে হলো, আপনি আপনার কম্পিউটারের ওয়েব ব্রাউজার থেকে আপনার হোস্ট করা কন্টেন্ট অ্যাক্সেস করতে পারবেন, কিন্তু আপনার নেটওয়ার্কের অন্য কোনো ডিভাইস থেকে পারবেন না। আপনি যদি অন্য লোকাল ডিভাইস থেকে পরীক্ষা করতে চান, তাহলে --host ফ্ল্যাগটি ব্যবহার করুন, যেমন:
firebase serve --host 0.0.0.0 // accepts requests to any host
একটি ফায়ারবেস প্রকল্পে স্থাপন করুন
Firebase CLI আপনার Firebase প্রোজেক্টে কোড এবং অ্যাসেট ডেপ্লয়মেন্ট পরিচালনা করে, যার মধ্যে অন্তর্ভুক্ত রয়েছে:
- আপনার Firebase Hosting সাইটগুলির নতুন রিলিজ
- Cloud Functions for Firebase
- Firebase SQL Connect জন্য নতুন বা হালনাগাদ করা স্কিমা এবং কানেক্টর
- Firebase Realtime Database জন্য Security Rules
- Cloud Storage for Firebase জন্য Security Rules
- Cloud Firestore জন্য Security Rules
- Cloud Firestore জন্য সূচক
- Authentication জন্য কনফিগারেশন
ফায়ারবেস প্রজেক্টে ডিপ্লয় করতে, আপনার প্রজেক্ট ডিরেক্টরি থেকে নিম্নলিখিত কমান্ডটি চালান:
firebase deploy
আপনি চাইলে আপনার প্রতিটি ডেপ্লয়মেন্টে একটি মন্তব্য যোগ করতে পারেন। এই মন্তব্যটি আপনার প্রোজেক্টের Firebase Hosting পেজে অন্যান্য ডেপ্লয়মেন্ট তথ্যের সাথে প্রদর্শিত হবে। উদাহরণস্বরূপ:
firebase deploy -m "Deploying the best new feature ever."
firebase deploy কমান্ড ব্যবহার করার সময় নিম্নলিখিত বিষয়গুলো সম্পর্কে সচেতন থাকুন:
প্রজেক্ট ডিরেক্টরি থেকে রিসোর্স ডেপ্লয় করতে হলে, সেই ডিরেক্টরিতে অবশ্যই একটি
firebase.jsonফাইল থাকতে হবে। `firebase initকমান্ডের মাধ্যমে এই ফাইলটি আপনার জন্য স্বয়ংক্রিয়ভাবে তৈরি হয়ে যায়।ডিফল্টরূপে,
firebase deployআপনার প্রজেক্ট ডিরেক্টরিতে থাকা সমস্ত ডেপ্লয়যোগ্য রিসোর্সের জন্য একটি রিলিজ তৈরি করে। নির্দিষ্ট ফায়ারবেস সার্ভিস বা ফিচার ডেপ্লয় করতে, `পার্শিয়াল ডেপ্লয়মেন্ট` ব্যবহার করুন ।
নির্দিষ্ট ফায়ারবেস পরিষেবাগুলি স্থাপন করুন
আপনি যদি শুধু নির্দিষ্ট Firebase পরিষেবা বা বৈশিষ্ট্যগুলি স্থাপন করতে চান, তাহলে firebase deploy কমান্ডে একটি ফ্ল্যাগের মধ্যে কমা দিয়ে আলাদা করা একটি তালিকা ব্যবহার করতে পারেন। উদাহরণস্বরূপ, নিম্নলিখিত কমান্ডটি Firebase Hosting কন্টেন্ট এবং Cloud Storage Security Rules স্থাপন করে।
firebase deploy --only hosting,storage
নিম্নলিখিত সারণীতে আংশিক ডেপ্লয়মেন্টের জন্য উপলব্ধ পরিষেবা এবং বৈশিষ্ট্যগুলির তালিকা দেওয়া হয়েছে। ফ্ল্যাগগুলিতে থাকা নামগুলি আপনার firebase.json কনফিগারেশন ফাইলের কী-গুলির সাথে সঙ্গতিপূর্ণ।
| ফ্ল্যাগ সিনট্যাক্স | পরিষেবা বা বৈশিষ্ট্য স্থাপন করা হয়েছে |
|---|---|
--only auth | Authentication প্রদানকারী কনফিগারেশন |
--only database | Firebase Realtime Database Security Rules |
--only dataconnect | Firebase SQL Connect স্কিমা এবং সংযোগকারী |
--only firestore | কনফিগার করা সমস্ত ডেটাবেসের জন্য Cloud Firestore Security Rules এবং সূচক |
--only functions | Cloud Functions for Firebase |
--only hosting | Firebase Hosting কন্টেন্ট |
--only storage | ফায়ারবেস Security Rules Cloud Storage for Firebase |
Security Rules জন্য স্থাপনা দ্বন্দ্ব
Firebase Realtime Database , Cloud Storage for Firebase , এবং Cloud Firestore জন্য, আপনি আপনার স্থানীয় প্রজেক্ট ডিরেক্টরিতে অথবা Firebase কনসোলে Security Rules নির্ধারণ করতে পারেন।
ডিপ্লয়মেন্ট দ্বন্দ্ব এড়ানোর আরেকটি উপায় হলো পার্শিয়াল ডিপ্লয়মেন্ট ব্যবহার করা এবং শুধুমাত্র Firebase কনসোলে Security Rules নির্ধারণ করা।
প্রিডিপ্লয় এবং পোস্টডিপ্লয় স্ক্রিপ্টেড টাস্ক সেট আপ করুন
আপনি প্রি-ডিপ্লয় বা পোস্ট-ডিপ্লয় টাস্ক সম্পাদন করার জন্য firebase deploy কমান্ডের সাথে শেল স্ক্রিপ্ট সংযুক্ত করতে পারেন। উদাহরণস্বরূপ, একটি প্রি-ডিপ্লয় স্ক্রিপ্ট টাইপস্ক্রিপ্ট কোডকে জাভাস্ক্রিপ্টে ট্রান্সপাইল করতে পারে, এবং একটি পোস্ট-ডিপ্লয় হুক Firebase Hosting এ নতুন সাইট কন্টেন্ট ডিপ্লয় হওয়ার বিষয়ে অ্যাডমিনিস্ট্রেটরদের অবহিত করতে পারে।
প্রিডিপ্লয় বা পোস্টডিপ্লয় হুক সেট আপ করতে, আপনার firebase.json কনফিগারেশন ফাইলে ব্যাশ স্ক্রিপ্ট যোগ করুন। আপনি সরাসরি firebase.json ফাইলে সংক্ষিপ্ত স্ক্রিপ্ট সংজ্ঞায়িত করতে পারেন, অথবা আপনার প্রজেক্ট ডিরেক্টরিতে থাকা অন্যান্য ফাইল রেফারেন্স করতে পারেন।
উদাহরণস্বরূপ, নিম্নলিখিত স্ক্রিপ্টটি একটি পোস্টডিপ্লয় টাস্কের firebase.json এক্সপ্রেশন, যা Firebase Hosting এ সফলভাবে ডিপ্লয়মেন্ট সম্পন্ন হলে একটি স্ল্যাক মেসেজ পাঠায়।
"hosting": {
// ...
"postdeploy": "./messageSlack.sh 'Just deployed to Firebase Hosting'",
"public": "public"
}
messageSlack.sh স্ক্রিপ্ট ফাইলটি প্রজেক্ট ডিরেক্টরিতে থাকে এবং দেখতে এইরকম:
curl -X POST -H 'Content-type: application/json' --data '{"text":"$1"}'
\https://SLACK_WEBHOOK_URLআপনি যে কোনো অ্যাসেট ডিপ্লয় করতে পারেন, সেগুলোর জন্য predeploy এবং postdeploy হুক সেট আপ করতে পারেন। মনে রাখবেন যে, firebase deploy চালালে আপনার firebase.json ফাইলে সংজ্ঞায়িত সমস্ত প্রিডিপ্লয় এবং পোস্টডিপ্লয় টাস্ক ট্রিগার হয়। শুধুমাত্র একটি নির্দিষ্ট ফায়ারবেস সার্ভিসের সাথে যুক্ত টাস্কগুলো চালানোর জন্য, পার্শিয়াল ডিপ্লয়মেন্ট কমান্ড ব্যবহার করুন ।
predeploy এবং postdeploy উভয় হুকই স্ক্রিপ্টগুলোর স্ট্যান্ডার্ড আউটপুট এবং এরর স্ট্রিম টার্মিনালে প্রিন্ট করে। ব্যর্থতার ক্ষেত্রে, নিম্নলিখিত বিষয়গুলো লক্ষ্য করুন:
- যদি কোনো প্রিডিপ্লয় হুক প্রত্যাশিতভাবে সম্পন্ন হতে ব্যর্থ হয়, তাহলে ডিপ্লয়মেন্ট বাতিল হয়ে যায়।
- কোনো কারণে ডেপ্লয়মেন্ট ব্যর্থ হলে, পোস্টডেপ্লয় হুকগুলো ট্রিগার হয় না।
পরিবেশগত পরিবর্তনশীল
প্রিডিপ্লয় এবং পোস্টডিপ্লয় হুকগুলিতে চলমান স্ক্রিপ্টগুলির মধ্যে নিম্নলিখিত এনভায়রনমেন্ট ভেরিয়েবলগুলি উপলব্ধ থাকে:
-
$GCLOUD_PROJECT: সক্রিয় প্রকল্পের প্রজেক্ট আইডি -
$PROJECT_DIR: মূল ডিরেক্টরি যেখানেfirebase.jsonফাইলটি রয়েছে -
$RESOURCE_DIR: (শুধুমাত্রhostingএবংfunctionsস্ক্রিপ্টের জন্য) যে ডিরেক্টরিতে স্থাপনযোগ্য Hosting বা Cloud Functions রিসোর্সগুলো থাকে, তার অবস্থান।
মোতায়েন কোটা
এমনটা হতে পারে (যদিও এর সম্ভাবনা কম) যে আপনি আপনার Firebase ডেপ্লয়মেন্ট অপারেশনের হার বা পরিমাণ সীমিত করে রাখা কোটা অতিক্রম করে ফেলতে পারেন। উদাহরণস্বরূপ, খুব বেশি সংখ্যক ফাংশন ডেপ্লয় করার সময়, আপনি একটি HTTP 429 Quota এরর মেসেজ পেতে পারেন। এই ধরনের সমস্যা সমাধানের জন্য, পার্শিয়াল ডেপ্লয়মেন্ট ব্যবহার করে দেখুন।
একটি ডেপ্লয়মেন্ট বাতিল করুন
আপনার প্রোজেক্টের Firebase Hosting পেজ থেকে নির্বাচিত রিলিজের জন্য Rollback অ্যাকশনটি সিলেক্ট করে আপনি একটি Firebase Hosting ডিপ্লয়মেন্ট রোল ব্যাক করতে পারেন।
Firebase Realtime Database , Cloud Storage for Firebase , বা Cloud Firestore এর Security Rules এর রিলিজগুলো রোল ব্যাক করা সম্ভব নয়।
কমান্ড রেফারেন্স
CLI প্রশাসনিক কমান্ড
| আদেশ | বর্ণনা |
|---|---|
| সাহায্য | CLI বা নির্দিষ্ট কমান্ড সম্পর্কে সহায়ক তথ্য প্রদর্শন করে। |
| ইনিট | বর্তমান ডিরেক্টরিতে একটি নতুন ফায়ারবেস প্রজেক্ট সংযুক্ত ও সেট আপ করে। এই কমান্ডটি বর্তমান ডিরেক্টরিতে একটি firebase.json কনফিগারেশন ফাইল তৈরি করে। |
| লগইন | আপনার গুগল অ্যাকাউন্ট দিয়ে CLI-কে প্রমাণীকরণ করে। এর জন্য একটি ওয়েব ব্রাউজারে অ্যাক্সেস প্রয়োজন। যেসব রিমোট এনভায়রনমেন্টে localhost অ্যাক্সেসের অনুমতি নেই, সেখানে CLI-তে লগ ইন করতে ব্যবহার করুন--no-localhost ফ্ল্যাগ। |
| লগইন:সিআই | অ-ইন্টারেক্টিভ পরিবেশে ব্যবহারের জন্য একটি প্রমাণীকরণ টোকেন তৈরি করে। |
| লগইন: যোগ করুন | একটি অতিরিক্ত গুগল অ্যাকাউন্ট লগ ইন করে। |
| লগইন:তালিকা | সকল যাচাইকৃত গুগল অ্যাকাউন্টের তালিকা। |
| লগইন: ব্যবহার করুন | সক্রিয় গুগল অ্যাকাউন্টটি সেট করে। |
| লগআউট | CLI থেকে আপনার গুগল অ্যাকাউন্ট সাইন আউট করুন। |
| খোলা | প্রাসঙ্গিক প্রজেক্ট রিসোর্সগুলো দেখার জন্য ব্রাউজার খোলে। |
| প্রকল্প:তালিকা | আপনার অ্যাক্সেস আছে এমন সমস্ত ফায়ারবেস প্রোজেক্টের তালিকা দেখায়। |
| ব্যবহার | CLI-এর জন্য সক্রিয় Firebase প্রজেক্ট সেট করে। প্রকল্পের বিকল্প নামগুলো পরিচালনা করে। |
প্রকল্প ব্যবস্থাপনার নির্দেশাবলী
| আদেশ | বর্ণনা | |
|---|---|---|
| ফায়ারবেস প্রোজেক্টের ব্যবস্থাপনা | ||
| প্রকল্প: অ্যাডফায়ারবেস | বিদ্যমান Google Cloud প্রকল্পে ফায়ারবেস রিসোর্স যুক্ত করে। | |
| প্রকল্প: তৈরি করুন | একটি নতুন Google Cloud প্রজেক্ট তৈরি করে, তারপর সেই নতুন প্রজেক্টে ফায়ারবেস রিসোর্স যুক্ত করে। | |
| প্রকল্প:তালিকা | আপনার অ্যাক্সেস আছে এমন সমস্ত ফায়ারবেস প্রোজেক্টের তালিকা দেখায়। | |
| ফায়ারবেস অ্যাপস (আইওএস, অ্যান্ড্রয়েড, ওয়েব) পরিচালনা | ||
| অ্যাপস: তৈরি করুন | সক্রিয় প্রজেক্টে একটি নতুন ফায়ারবেস অ্যাপ তৈরি করে। | |
| অ্যাপস:তালিকা | সক্রিয় প্রোজেক্টে নিবন্ধিত ফায়ারবেস অ্যাপগুলোর তালিকা দেখায়। | |
| অ্যাপস:এসডিকেকনফিগ | একটি ফায়ারবেস অ্যাপের গুগল পরিষেবা কনফিগারেশন প্রিন্ট করে। | |
| সেটআপ:ওয়েব | অপ্রচলিত। এর পরিবর্তে, apps:sdkconfig ব্যবহার করুন এবং প্ল্যাটফর্ম আর্গুমেন্ট হিসেবে web উল্লেখ করুন।একটি ফায়ারবেস ওয়েব অ্যাপের গুগল পরিষেবা কনফিগারেশন প্রিন্ট করে। | |
| SHA সার্টিফিকেট হ্যাশগুলির ব্যবস্থাপনা (শুধুমাত্র অ্যান্ড্রয়েডের জন্য) | ||
| অ্যাপস:অ্যান্ড্রয়েড:শা:তৈরি করুন FIREBASE_APP_ID SHA_HASH | নির্দিষ্ট SHA সার্টিফিকেট হ্যাশটি নির্দিষ্ট Firebase Android অ্যাপে যুক্ত করে। | |
| অ্যাপস:অ্যান্ড্রয়েড:শা:মুছে ফেলুন FIREBASE_APP_ID SHA_HASH | নির্দিষ্ট Firebase অ্যান্ড্রয়েড অ্যাপ থেকে নির্দিষ্ট SHA সার্টিফিকেট হ্যাশটি মুছে ফেলে। | |
| অ্যাপস:অ্যান্ড্রয়েড:শা:তালিকা FIREBASE_APP_ID | নির্দিষ্ট ফায়ারবেস অ্যান্ড্রয়েড অ্যাপটির SHA সার্টিফিকেট হ্যাশগুলো তালিকাভুক্ত করে। | |
মোতায়েন এবং স্থানীয় উন্নয়ন
এই কমান্ডগুলো আপনাকে আপনার Firebase Hosting সাইট স্থাপন করতে এবং এর সাথে ইন্টারঅ্যাক্ট করতে সাহায্য করে।
| আদেশ | বর্ণনা |
|---|---|
| মোতায়েন করুন | আপনার প্রজেক্ট ডিরেক্টরি থেকে সক্রিয় প্রজেক্টে কোড এবং অ্যাসেট স্থাপন করে। Firebase Hosting জন্য একটি firebase.json কনফিগারেশন ফাইল প্রয়োজন। |
| পরিবেশন করুন | আপনার Firebase Hosting কনফিগারেশন দিয়ে একটি স্থানীয় ওয়েব সার্ভার চালু করে। Firebase Hosting জন্য একটি firebase.json কনফিগারেশন ফাইল প্রয়োজন। |
App Distribution কমান্ড
| আদেশ | বর্ণনা |
|---|---|
| অ্যাপডিস্ট্রিবিউশন:ডিস্ট্রিবিউট \ --অ্যাপ FIREBASE_APP_ID | বিল্ডটি পরীক্ষকদের জন্য উপলব্ধ করে। |
| অ্যাপডিস্ট্রিবিউশন:টেস্টার:অ্যাড | প্রকল্পে পরীক্ষকদের যুক্ত করে। |
| অ্যাপডিস্ট্রিবিউশন:টেস্টার:রিমুভ | প্রজেক্ট থেকে টেস্টারদের সরিয়ে দেয়। |
| অ্যাপডিস্ট্রিবিউশন:টেস্টার:তালিকা | প্রকল্পের পরীক্ষকদের তালিকা দেখায়। |
| অ্যাপডিস্ট্রিবিউশন:গ্রুপস:ক্রিয়েট | একটি পরীক্ষক গোষ্ঠী তৈরি করে। |
| অ্যাপডিস্ট্রিবিউশন:গ্রুপস:ডিলিট | পরীক্ষক গোষ্ঠী মুছে দেয়। |
| অ্যাপডিস্ট্রিবিউশন:গ্রুপ:তালিকা | প্রকল্পের পরীক্ষক গোষ্ঠীগুলির তালিকা দেখায়। |
App Hosting কমান্ড
| আদেশ | বর্ণনা |
|---|---|
| অ্যাপহোস্টিং:ব্যাকএন্ডস:তৈরি করুন --প্রকল্প PROJECT_ID \ --অবস্থান REGION --অ্যাপ APP_ID | একটি একক কোডবেসের সাথে সংযুক্ত পরিচালিত রিসোর্সসমূহের একটি সংগ্রহ তৈরি করে, যা একটি App Hosting ব্যাকএন্ড গঠন করে। ঐচ্ছিকভাবে, এর ফায়ারবেস অ্যাপ আইডি ব্যবহার করে একটি বিদ্যমান ফায়ারবেস ওয়েব অ্যাপ নির্দিষ্ট করা যেতে পারে। |
| অ্যাপহোস্টিং:ব্যাকএন্ডস:গেট \ BACKEND_ID --প্রকল্প PROJECT_ID \ --অবস্থান REGION | একটি ব্যাকএন্ডের পাবলিক ইউআরএল সহ নির্দিষ্ট বিবরণ পুনরুদ্ধার করে। |
| অ্যাপহোস্টিং:ব্যাকএন্ডস:তালিকা --প্রকল্প PROJECT_ID | একটি প্রকল্পের সাথে যুক্ত সমস্ত সক্রিয় ব্যাকএন্ডের একটি তালিকা পুনরুদ্ধার করে। |
| firebase apphosting:backends:delete \ BACKEND_ID --প্রকল্প PROJECT_ID \ --অবস্থান REGION | প্রজেক্ট থেকে একটি ব্যাকএন্ড মুছে ফেলে। |
| firebase apphosting:config:export \ --প্রকল্প PROJECT_ID \ --গোপনীয় ENVIRONMENT_NAME | অ্যাপ এমুলেশনে ব্যবহারের জন্য গোপনীয় তথ্য রপ্তানি করে। ডিফল্টরূপে apphosting.yaml এ সংরক্ষিত সিক্রেট ব্যবহৃত হয়, অথবা --secrets ব্যবহার করে এমন যেকোনো এনভায়রনমেন্ট নির্দিষ্ট করা যায় যার একটি সংশ্লিষ্ট apphosting. ENVIRONMENT_NAME .yaml ফাইল রয়েছে। |
| firebase apphosting:rollouts:create \ BACKEND_ID --git_branch BRANCH_NAME \ --git_commit COMMIT_ID | ম্যানুয়ালি চালু করার মতো একটি রোলআউট তৈরি করে। ঐচ্ছিকভাবে কোনো ব্রাঞ্চের সর্বশেষ কমিট অথবা একটি নির্দিষ্ট কমিট উল্লেখ করুন। কোনো অপশন না দেওয়া হলে, ব্রাঞ্চের তালিকা থেকে বেছে নেওয়ার জন্য অনুরোধ করা হয়। |
| apphosting:secrets:set KEY --project PROJECT_ID \ --অবস্থান REGION \ --ডেটা-ফাইল DATA_FILE_PATH | সিক্রেট ম্যানেজারে গোপনীয় উপাদান সংরক্ষণ করে। ঐচ্ছিকভাবে গোপন ডেটা পড়ার জন্য একটি পথ প্রদান করুন। স্ট্যান্ডার্ড ইনপুট থেকে গোপন ডেটা পড়তে এটিকে _ তে সেট করুন। |
| অ্যাপহোস্টিং:সিক্রেটস:গ্রান্টঅ্যাক্সেস KEY BACKEND_ID \ --প্রকল্প PROJECT_ID \ --অবস্থান REGION | ব্যাকএন্ড সার্ভিস অ্যাকাউন্টকে প্রদত্ত সিক্রেটটিতে অ্যাক্সেস দেওয়া হয়, যাতে App Hosting বিল্ড বা রান টাইমে এটি অ্যাক্সেস করতে পারে। |
| apphosting:secrets:describe KEY \ --প্রকল্প PROJECT_ID | একটি গোপনীয় তথ্য এবং এর সংস্করণগুলির মেটাডেটা সংগ্রহ করে। |
| firebase apphosting:secrets:access \ KEY[@version] \ --প্রকল্প PROJECT_ID | সিক্রেট এবং এর ভার্সন দেওয়া থাকলে একটি সিক্রেট ভ্যালু অ্যাক্সেস করা যায়। ডিফল্টরূপে সর্বশেষ ভার্সনটি অ্যাক্সেস করা হয়। |
Authentication (ব্যবহারকারী ব্যবস্থাপনা) কমান্ড
| আদেশ | বর্ণনা |
|---|---|
| প্রমাণীকরণ:রপ্তানি | সক্রিয় প্রজেক্টের ব্যবহারকারী অ্যাকাউন্টগুলো একটি JSON বা CSV ফাইলে রপ্তানি করে। আরও বিস্তারিত জানতে, auth:import এবং auth:export পৃষ্ঠাটি দেখুন। |
| প্রমাণীকরণ: আমদানি | একটি JSON বা CSV ফাইল থেকে ব্যবহারকারীর অ্যাকাউন্টগুলো সক্রিয় প্রজেক্টে ইম্পোর্ট করে। আরও বিস্তারিত জানতে, auth:import এবং auth:export পেজটি দেখুন। |
Cloud Firestore কমান্ড
| আদেশ | বর্ণনা |
|---|---|
| ফায়ারস্টোর:অবস্থান | আপনার Cloud Firestore ডেটাবেসের জন্য উপলব্ধ অবস্থানগুলির তালিকা করুন। |
| firestore:databases:create DATABASE_ID | আপনার Firebase প্রজেক্টে নেটিভ মোডে একটি ডাটাবেস ইনস্ট্যান্স তৈরি করুন। এই কমান্ডটি নিম্নলিখিত ফ্ল্যাগগুলো গ্রহণ করে:
|
| ফায়ারস্টোর:ডাটাবেস:তালিকা | আপনার ফায়ারবেস প্রোজেক্টের ডেটাবেসগুলোর তালিকা করুন। |
| firestore:databases:get DATABASE_ID | আপনার Firebase প্রোজেক্টের একটি নির্দিষ্ট ডাটাবেসের কনফিগারেশন জেনে নিন। এন্টারপ্রাইজ ডেটাবেসগুলির জন্য, আউটপুটে |
| firestore:databases:update DATABASE_ID | আপনার ফায়ারবেস প্রজেক্টের একটি নির্দিষ্ট ডেটাবেসের কনফিগারেশন আপডেট করুন। অন্তত একটি ফ্ল্যাগ আবশ্যক। কমান্ডটি নিম্নলিখিত ফ্ল্যাগগুলো গ্রহণ করে:
|
| firestore:databases:delete DATABASE_ID | আপনার ফায়ারবেস প্রজেক্ট থেকে একটি ডেটাবেস মুছে ফেলুন। |
| ফায়ারস্টোর:সূচক | আপনার ফায়ারবেস প্রজেক্টের ডাটাবেসের ইনডেক্সগুলো তালিকাভুক্ত করুন। কমান্ডটি নিম্নলিখিত ফ্ল্যাগটি গ্রহণ করে:
|
| ফায়ারস্টোর:মুছে ফেলুন | সক্রিয় প্রজেক্টের ডাটাবেস থেকে ডকুমেন্ট মুছে ফেলে। CLI ব্যবহার করে, আপনি একটি কালেকশনের সমস্ত ডকুমেন্ট রিকার্সিভলি মুছে ফেলতে পারেন। মনে রাখবেন যে, CLI ব্যবহার করে Cloud Firestore ডেটা ডিলিট করলে রিড এবং ডিলিট উভয় খরচই প্রযোজ্য হয়। আরও তথ্যের জন্য, ‘আন্ডারস্ট্যান্ড Cloud Firestore বিলিং’ দেখুন। কমান্ডটি নিম্নলিখিত ফ্ল্যাগটি গ্রহণ করে:
|
Cloud Functions for Firebase commands
| আদেশ | বর্ণনা |
|---|---|
| functions:config:clone | অপ্রচলিত। Clones another project's environment into the active Firebase project. |
| functions:config:export | Exports the active project's runtime configuration to Google Cloud Secret Manager . |
| functions:config:get | অপ্রচলিত। Retrieves existing configuration values of the active project's Cloud Functions . |
| functions:config:set | অপ্রচলিত। Stores runtime configuration values of the active project's Cloud Functions . |
| functions:config:unset | অপ্রচলিত। Removes values from the active project's runtime configuration. |
| functions:delete \ FUNCTION_NAME | Deletes the specified function. |
| functions:list | Lists deployed functions. |
| functions:log | Reads logs from deployed Cloud Functions . |
| functions:secrets:access \ SECRET_NAME | Accesses a secret value given the secret and its version. |
| functions:secrets:destroy \ SECRET_NAME | Destroys a secret. |
| functions:secrets:get \ SECRET_NAME | Gets the metadata for a secret and its versions. |
| functions:secrets:prune | Destroys unused secrets. |
| functions:secrets:set \ SECRET_NAME | Creates or updates a secret. |
| functions:shell | Starts a local interactive shell for testing functions. |
For more information, refer to the environment configuration documentation .
Crashlytics commands
| আদেশ | বর্ণনা |
|---|---|
| crashlytics:mappingfile:generateid \ --resource-file= PATH/TO/ANDROID_RESOURCE.XML | Generates a unique mapping file ID in the specified Android resource (XML) file. |
| crashlytics:mappingfile:upload \ --app= FIREBASE_APP_ID \ --resource-file= PATH/TO/ANDROID_RESOURCE.XML \ PATH/TO/MAPPING_FILE.TXT | Uploads a Proguard-compatible mapping (TXT) file for this app, and associates it with the mapping file ID declared in the specified Android resource (XML) file. |
| crashlytics:symbols:upload \ --app= FIREBASE_APP_ID \ PATH/TO/SYMBOLS | Generates a Crashlytics -compatible symbol file for native library crashes on Android and uploads it to Firebase servers. |
SQL Connect commands
These commands and their use cases are covered in more detail in the SQL Connect CLI reference guide .
| আদেশ | বর্ণনা |
|---|---|
| dataconnect:services:list | Lists all deployed SQL Connect services in your Firebase project. |
| dataconnect:sql:diff \ SERVICE_ID | For the specified service, displays the differences between a local SQL Connect schema and your Cloud SQL database schema. |
| dataconnect:sql:migrate \ --force \ SERVICE_ID | Migrates your Cloud SQL database's schema to match your local SQL Connect schema. |
| dataconnect:sql:grant\ --role= ROLE \ --email= EMAIL \ SERVICE_ID | Grants the SQL role to the specified user or service account email. For the --role flag, the SQL role to grant is one of: owner , writer , or reader .For the --email flag, provide the email address of the user or service account to grant the role to. |
| dataconnect:sdk:generate | Generates typed SDKs for your SQL Connect connectors. |
Extensions commands
| আদেশ | বর্ণনা |
|---|---|
| এক্সট | Displays information on how to use Firebase Extensions commands. Lists the extension instances installed in the active project. |
| ext:configure \ EXTENSION_INSTANCE_ID | Reconfigures the parameter values of an extension instance in your extension manifest . |
| ext:info \ PUBLISHER_ID/EXTENSION_ID | Prints detailed information about an extension. |
| ext:install \ PUBLISHER_ID/EXTENSION_ID | Adds a new instance of an extension into your extension manifest . |
| ext:sdk:install | Installs SDKs for defining extensions in functions. |
| ext:list | Lists all the extension instances installed in a Firebase project. Prints the instance ID for each extension. |
| ext:uninstall \ EXTENSION_INSTANCE_ID | Removes an extension instance from your extension manifest . |
| ext:update \ EXTENSION_INSTANCE_ID | Updates an extension instance to the latest version in your extension manifest . |
| ext:export | Exports all installed extension instances from your project to your extension manifest . |
Extensions publisher commands
| আদেশ | বর্ণনা |
|---|---|
| ext:dev:init | Initializes a skeleton codebase for a new extension in the current directory. |
| ext:dev:list \ PUBLISHER_ID | Prints a list of all extensions uploaded by a publisher. |
| ext:dev:register | Registers a Firebase project as an extensions publisher project . |
| ext:dev:deprecate \ PUBLISHER_ID/EXTENSION_ID \ VERSION_PREDICATE | Deprecates extension versions that match the version predicate. A version predicate can be a single version (such as 1.0.0 ), or a range of versions (such as >1.0.0 ).If no version predicate is provided, deprecates all versions of that extension. |
| ext:dev:undeprecate \ PUBLISHER_ID/EXTENSION_ID \ VERSION_PREDICATE | Undeprecates extension versions that match the version predicate. A version predicate can be a single version (such as 1.0.0 ), or a range of versions (such as >1.0.0 ).If no version predicate is provided, undeprecates all versions of that extension. |
| ext:dev:upload \ PUBLISHER_ID/EXTENSION_ID | Uploads a new version of an extension. |
| ext:dev:usage \ PUBLISHER_ID | Displays install counts and usage metrics for extensions uploaded by a publisher. |
Hosting commands
| আদেশ | বর্ণনা |
|---|---|
| hosting:disable | Stops serving Firebase Hosting traffic for the active Firebase project. Your project's Hosting URL will display a "Site Not Found" message after running this command. |
| Management of Hosting sites | |
| firebase hosting:sites:create \ SITE_ID | Creates a new Hosting site in the active Firebase project using the specified (Optional) Specify an existing Firebase Web App to associate with the new site by passing the following flag: |
| firebase hosting:sites:delete \ SITE_ID | Deletes the specified Hosting site The CLI displays a confirmation prompt before deleting the site. (Optional) Skip the confirmation prompt by passing the following flags: |
| firebase hosting:sites:get \ SITE_ID | Retrieves information about the specified Hosting site |
| firebase hosting:sites:list | Lists all Hosting sites for the active Firebase project |
| Management of preview channels | |
| firebase hosting:channel:create \ CHANNEL_ID | Creates a new preview channel in the default Hosting site using the specified This command doesn't deploy to the channel. |
| firebase hosting:channel:delete \ CHANNEL_ID | Deletes the specified preview channel You cannot delete a site's live channel. |
| firebase hosting:channel:deploy \ CHANNEL_ID | Deploys your Hosting content and config to the specified preview channel If the preview channel doesn't yet exist, this command creates the channel in the default Hosting site before deploying to the channel. |
| firebase hosting:channel:list | Lists all channels (including the "live" channel) in the default Hosting site |
| firebase hosting:channel:open \ CHANNEL_ID | Opens a browser to the specified channel's URL or returns the URL if opening in a browser isn't possible |
| Version cloning | |
| firebase hosting:clone \ SOURCE_SITE_ID : SOURCE_CHANNEL_ID \ TARGET_SITE_ID : TARGET_CHANNEL_ID | Clones the most recently deployed version on the specified "source" channel to the specified "target" channel This command also deploys to the specified "target" channel. If the "target" channel doesn't yet exist, this command creates a new preview channel in the "target" Hosting site before deploying to the channel. |
| firebase hosting:clone \ SOURCE_SITE_ID :@ VERSION_ID \ TARGET_SITE_ID : TARGET_CHANNEL_ID | Clones the specified version to the specified "target" channel This command also deploys to the specified "target" channel. If the "target" channel doesn't yet exist, this command creates a new preview channel in the "target" Hosting site before deploying to the channel. You can find the |
Realtime Database commands
Note that you can create your initial, default Realtime Database instance in the Firebase console or by using the general firebase init workflow or the specific firebase init database flow.
Once instances are created, you can manage them as described in Manage and interact with specific instances using the CLI .
| আদেশ | বর্ণনা |
|---|---|
| database:get | Fetches data from the active project's database and displays it as JSON. Supports querying on indexed data. |
| database:instances:create | Creates a database instance with a specified instance name. Accepts the --location option for creating a database in a specified region. For region names to use with this option, see select locations for your project . If no database instance exists for the current project, you are prompted to run the firebase init flow to create an instance. |
| database:instances:list | List all database instances for this project. Accepts the --location option for listing databases in a specified region. For region names to use with this option see select locations for your project . |
| database:profile | Builds a profile of operations on the active project's database. For more details, refer to Realtime Database operation types . |
| database:push | Pushes new data to a list at a specified location in the active project's database. Takes input from a file, STDIN, or a command-line argument. |
| database:remove | Deletes all data at a specified location in the active project's database. |
| database:set | Replaces all data at a specified location in the active project's database. Takes input from a file, STDIN, or a command-line argument. |
| database:update | Performs a partial update at a specified location in the active project's database. Takes input from a file, STDIN, or a command-line argument. |
Remote Config commands
| আদেশ | বর্ণনা |
|---|---|
| remoteconfig:versions:list \ --limit NUMBER_OF_VERSIONS | Lists the most recent ten versions of the template. Specify 0 to return all existing versions, or optionally pass the --limit option to limit the number of versions being returned. |
| remoteconfig:get \ --v, version_number VERSION_NUMBER --o, output FILENAME | Gets the template by version (defaults to the latest version) and outputs the parameter groups, parameters, and condition names and version into a table. Optionally, you can write the output to a specified file with -o, FILENAME . |
| remoteconfig:rollback \ --v, version_number VERSION_NUMBER --force | Rolls back Remote Config template to a specified previous version number or defaults to the immediate previous version (current version -1). Unless --force is passed, prompts Y/N before proceeding to rollback. |
| remoteconfig:experiments:list \ --filter EXPRESSION --pageSize NUMBER --pageToken TOKEN | Lists all Remote Config experiments for a project, with optional filtering, number of experiments to return per page (defaults to 10), and page token as the starting offset for the list. |
| remoteconfig:experiments:get \ EXPERIMENT_ID | Gets the details of the specified Remote Config experiment. |
| remoteconfig:experiments:delete \ EXPERIMENT_ID | Deletes the specified Remote Config experiment. |
| remoteconfig:rollouts:list \ --filter EXPRESSION --pageSize NUMBER --pageToken TOKEN | Lists all Remote Config rollouts for a project, with optional filtering, number of rollouts to return per page (defaults to 10), and page token as the starting offset for the list. |
| remoteconfig:rollouts:get \ ROLLOUT_ID | Gets the details of the specified Remote Config rollout. |
| remoteconfig:rollouts:delete \ ROLLOUT_ID | Deletes the specified Remote Config rollout. |