I have this problem and try to fix with all solutions I had found,but still not works. My rules in firebase cloud firestore is :
service cloud.firestore {
match /databases/{database}/documents {
match /{document=**} {
allow read, write : if auth != null ;
}
}
}
And I had already enable Sign-in Method Anonymously.
android/build.gradle
:
classpath 'com.android.tools.build:gradle:3.1.3'
classpath 'com.google.gms:google-services:4.0.1'
android/app/build.gradle
:
compile project(':react-native-firebase')
compile project(':react-native-fbsdk')
implementation project(':react-native-firebase')
implementation fileTree(dir: "libs", include: ["*.jar"])
implementation "com.android.support:appcompat-v7:${rootProject.ext.supportLibVersion}"
implementation "com.facebook.react:react-native:+" // From node_modules
implementation 'com.google.firebase:firebase-core:16.0.4'
implementation 'com.google.firebase:firebase-auth:16.0.4'
implementation 'com.google.firebase:firebase-firestore:17.1.0'
Testing.js
:
firebase.auth().signInAnonymously().then(()=>{
firebase.app().firestore().collection('Hello').doc('hello').set({
id:'fadsa'
}).catch((err)=>{
alert(err);
})
})
This is an issue because of the rules that your DB currently has. Please check both datebases, Realtime and Firestore.
As in general, having full security rules or any other rule that is not complitely understood by RD or CF logic will get you that error everytime.
> // Full security
>
> { "rules": {
> ".read": false,
> ".write": false } }
in Firestore you can configurate that as the following:
> service cloud.firestore { match /databases/{database}/documents {
> match /{document=**} {
> allow read: if auth != null;
> allow write: if auth != null;
> } } }
For more examples you can see: https://gist.github.com/codediodeio/6dbce1305b9556c2136492522e2100f6 https://firebase.google.com/docs/database/security