Firebase Security Rules এমন একটি ফর্ম্যাটে অ্যাক্সেস নিয়ন্ত্রণ এবং ডেটা ভ্যালিডেশন প্রদান করে যা একাধিক স্তরের জটিলতা সমর্থন করে। ব্যবহারকারী-ভিত্তিক এবং ভূমিকা-ভিত্তিক অ্যাক্সেস সিস্টেম তৈরি করতে যা আপনার ব্যবহারকারীদের ডেটা সুরক্ষিত রাখে, Firebase Security Rules সহ Firebase Authentication ব্যবহার করুন।
ব্যবহারকারীদের শনাক্ত করুন
Authentication আপনার ডেটা অ্যাক্সেসের অনুরোধকারী ব্যবহারকারীদের সনাক্ত করে এবং সেই তথ্যকে একটি ভেরিয়েবল হিসাবে প্রদান করে যা আপনি আপনার নিয়মগুলিতে ব্যবহার করতে পারেন। auth ভেরিয়েবলে নিম্নলিখিত তথ্য থাকে:
-
uid: অনুরোধকারী ব্যবহারকারীকে নির্ধারিত একটি অনন্য ব্যবহারকারী আইডি। -
token: Authentication দ্বারা সংগৃহীত মানগুলির একটি মানচিত্র।
auth.token ভেরিয়েবলে নিম্নলিখিত মানগুলি থাকে:
| মাঠ | বিবরণ |
|---|---|
email | অ্যাকাউন্টের সাথে সম্পর্কিত ইমেল ঠিকানা, যদি থাকে। |
email_verified | ব্যবহারকারী যদি যাচাই করে থাকেন যে তাদের email ঠিকানায় অ্যাক্সেস আছে, তাহলে true । কিছু প্রদানকারী স্বয়ংক্রিয়ভাবে তাদের মালিকানাধীন ইমেল ঠিকানা যাচাই করে। |
phone_number | অ্যাকাউন্টের সাথে সম্পর্কিত ফোন নম্বর, যদি থাকে। |
name | ব্যবহারকারীর প্রদর্শন নাম, যদি সেট করা থাকে। |
sub | ব্যবহারকারীর ফায়ারবেস ইউআইডি। এটি একটি প্রকল্পের মধ্যে অনন্য। |
firebase.identities | এই ব্যবহারকারীর অ্যাকাউন্টের সাথে সম্পর্কিত সমস্ত পরিচয়ের অভিধান। অভিধানের কীগুলি নিম্নলিখিত যেকোনো একটি হতে পারে: email , phone , google.com , facebook.com , github.com , twitter.com । অভিধানের মানগুলি হল অ্যাকাউন্টের সাথে সম্পর্কিত প্রতিটি পরিচয় প্রদানকারীর জন্য অনন্য শনাক্তকারীর অ্যারে। উদাহরণস্বরূপ, auth.token.firebase.identities["google.com"][0] অ্যাকাউন্টের সাথে সম্পর্কিত প্রথম Google ব্যবহারকারী আইডি ধারণ করে। |
firebase.sign_in_provider | এই টোকেনটি পেতে ব্যবহৃত সাইন-ইন প্রদানকারী। নিম্নলিখিত স্ট্রিংগুলির মধ্যে একটি হতে পারে: custom , password , phone , anonymous , google.com , facebook.com , github.com , twitter.com । |
firebase.tenant | অ্যাকাউন্টের সাথে সম্পর্কিত tenant Id, যদি থাকে। যেমন tenant2-m6tyz |
যদি আপনি কাস্টমাইজড প্রমাণীকরণ বৈশিষ্ট্য যোগ করতে চান, তাহলে auth.token ভেরিয়েবলে আপনার নির্দিষ্ট করা যেকোনো কাস্টম দাবিও থাকবে।
যখন অ্যাক্সেসের অনুরোধকারী ব্যবহারকারী সাইন ইন না করে থাকেন, তখন auth ভেরিয়েবলটি null হয়। উদাহরণস্বরূপ, যদি আপনি প্রমাণিত ব্যবহারকারীদের জন্য পঠন অ্যাক্সেস সীমিত করতে চান - auth != null , তাহলে আপনি আপনার নিয়মগুলিতে এটি ব্যবহার করতে পারেন। তবে, আমরা সাধারণত লেখার অ্যাক্সেস আরও সীমিত করার পরামর্শ দিই।
auth ভেরিয়েবল সম্পর্কে আরও তথ্যের জন্য, Cloud Firestore , Realtime Database এবং Cloud Storage রেফারেন্স ডকুমেন্টেশন দেখুন।
নিয়মে ব্যবহারকারীর তথ্য ব্যবহার করুন
বাস্তবে, আপনার নিয়মে প্রমাণীকৃত তথ্য ব্যবহার করা আপনার নিয়মগুলিকে আরও শক্তিশালী এবং নমনীয় করে তোলে। আপনি ব্যবহারকারীর পরিচয়ের উপর ভিত্তি করে ডেটা অ্যাক্সেস নিয়ন্ত্রণ করতে পারেন।
আপনার নিয়মগুলিতে, auth ভেরিয়েবলের তথ্য - অনুরোধকারীর ব্যবহারকারীর তথ্য - কীভাবে অনুরোধ করা ডেটার সাথে সম্পর্কিত ব্যবহারকারীর তথ্যের সাথে মেলে তা নির্ধারণ করুন।
উদাহরণস্বরূপ, আপনার অ্যাপটি নিশ্চিত করতে পারে যে ব্যবহারকারীরা কেবল তাদের নিজস্ব ডেটা পড়তে এবং লিখতে পারে। এই পরিস্থিতিতে, আপনি auth.uid ভেরিয়েবল এবং অনুরোধ করা ডেটার ব্যবহারকারী আইডির মধ্যে একটি মিল চাইবেন:
Cloud Firestore
service cloud.firestore {
match /databases/{database}/documents {
// Make sure the uid of the requesting user matches name of the user
// document. The wildcard expression {userId} makes the userId variable
// available in rules.
match /users/{userId} {
allow read, write: if request.auth != null && request.auth.uid == userId;
}
}
}
Realtime Database
{
"rules": {
"users": {
"$userId": {
// grants write access to the owner of this user account
// whose uid must exactly match the key ($userId)
".write": "$userId === auth.uid"
}
}
}
}
Cloud Storage
service firebase.storage {
// Only a user can upload their file, but anyone can view it
match /users/{userId}/{fileName} {
allow read;
allow write: if request.auth != null && request.auth.uid == userId;
}
}
কাস্টম ব্যবহারকারীর তথ্য নির্ধারণ করুন
আপনার অ্যাপের ব্যবহারকারীদের জন্য নির্ধারিত কাস্টম ক্ষেত্রগুলি সংজ্ঞায়িত করতে আপনি auth ভেরিয়েবলটি আরও ব্যবহার করতে পারেন।
উদাহরণস্বরূপ, ধরুন আপনি একটি "অ্যাডমিন" ভূমিকা তৈরি করতে চান যা নির্দিষ্ট পাথগুলিতে লেখার অ্যাক্সেস সক্ষম করে। আপনি সেই বৈশিষ্ট্যটি ব্যবহারকারীদের জন্য বরাদ্দ করবেন, এবং তারপর পাথগুলিতে অ্যাক্সেস প্রদানকারী নিয়মগুলিতে এটি ব্যবহার করবেন।
Cloud Firestore , আপনি ব্যবহারকারীদের ডকুমেন্টে একটি কাস্টম ফিল্ড যোগ করতে পারেন এবং আপনার নিয়মে এমবেডেড রিড ব্যবহার করে সেই ফিল্ডের মান পুনরুদ্ধার করতে পারেন। সুতরাং, আপনার অ্যাডমিন-ভিত্তিক নিয়মটি নিম্নলিখিত উদাহরণের মতো দেখাবে:
Cloud Firestore
service cloud.firestore {
match /databases/{database}/documents/some_collection: {
// Remember that, in Cloud Firestore, reads embedded in your rules are billed operations
write: if request.auth != null && get(/databases/(database)/documents/users/$(request.auth.uid)).data.admin == true;
read: if request.auth != null;
}
}
Authentication এ কাস্টম দাবি তৈরি করার পর আপনি Rules এ কাস্টম দাবি অ্যাক্সেস করতে পারবেন। তারপর আপনি auth.token ভেরিয়েবল ব্যবহার করে সেই কাস্টম দাবিগুলি উল্লেখ করতে পারবেন।
Cloud Firestore
service cloud.firestore {
match /databases/{database}/documents {
// For attribute-based access control, check for an admin claim
allow write: if request.auth.token.admin == true;
allow read: true;
// Alterntatively, for role-based access, assign specific roles to users
match /some_collection/{document} {
allow read: if request.auth.token.reader == "true";
allow write: if request.auth.token.writer == "true";
}
}
}
Realtime Database
{
"rules": {
"some_path": {
"$sub_path": {
// Create a custom claim for the admin role
".write": "auth.uid !== null && auth.token.writer === true",
".read": "auth.uid !== null"
}
}
}
}
Cloud Storage
service firebase.storage {
// Create a custom claim for the admin role
match /files/{fileName} {
allow read: if request.auth.uid != null;
allow write: if request.auth.token.admin == true;
}
}
Authentication সুবিধা গ্রহণের মৌলিক Rules আরও উদাহরণ দেখতে, মৌলিক নিরাপত্তা নিয়ম দেখুন।