Получение необработанного исключения: [cloud_firestore/permission-denied]. Я проверил, что все было в порядке в firebase

Привет, ребята, я создал приложение флаттера, в котором, когда пользователь нажимает кнопку регистрации, он будет проверять, существует ли указанная электронная почта в базе данных firestore или нет, если нет, то они будут перемещены на следующий экран. Я получаю это исключение [ERROR:flutter/runtime/dart_vm_initializer.cc(41)] Unhandled Exception: [cloud_firestore/permission-denied] The caller does not have permission to execute the specified operation., даже если в моем коде и конфигурации firestore все выглядит нормально.

Вот мои правила базы данных firestore:

rules_version = '2';
service cloud.firestore {
  match /databases/{database}/documents {
    match /{document=**} {
      allow read, write: if request.auth != null;
    }
  }
}

Вот мой уровень проекта build.gradle:

buildscript {
    ext.kotlin_version = '1.6.10'
    repositories {
        google()
        mavenCentral()
    }

    dependencies {
        classpath 'com.android.tools.build:gradle:7.1.2'
        classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
        classpath 'com.google.gms:google-services:4.3.13'
    }
}

allprojects {
    repositories {
        google()
        mavenCentral()
    }
}

rootProject.buildDir = '../build'
subprojects {
    project.buildDir = "${rootProject.buildDir}/${project.name}"
}
subprojects {
    project.evaluationDependsOn(':app')
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

Вот мой build.gradle на уровне приложения

def localProperties = new Properties()
def localPropertiesFile = rootProject.file('local.properties')
if (localPropertiesFile.exists()) {
    localPropertiesFile.withReader('UTF-8') { reader ->
        localProperties.load(reader)
    }
}

def flutterRoot = localProperties.getProperty('flutter.sdk')
if (flutterRoot == null) {
    throw new GradleException("Flutter SDK not found. Define location with flutter.sdk in the local.properties file.")
}

def flutterVersionCode = localProperties.getProperty('flutter.versionCode')
if (flutterVersionCode == null) {
    flutterVersionCode = '1'
}

def flutterVersionName = localProperties.getProperty('flutter.versionName')
if (flutterVersionName == null) {
    flutterVersionName = '1.0'
}

apply plugin: 'com.android.application'
apply plugin: 'com.google.gms.google-services'
apply plugin: 'kotlin-android'
apply from: "$flutterRoot/packages/flutter_tools/gradle/flutter.gradle"

android {
    compileSdkVersion flutter.compileSdkVersion
    ndkVersion flutter.ndkVersion

    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_8
        targetCompatibility JavaVersion.VERSION_1_8
    }

    kotlinOptions {
        jvmTarget = '1.8'
    }

    sourceSets {
        main.java.srcDirs += 'src/main/kotlin'
    }

    defaultConfig {
        // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html).
        applicationId "com.recipedia.fyp.recipedia"
        // You can update the following values to match your application needs.
        // For more information, see: https://docs.flutter.dev/deployment/android#reviewing-the-build-configuration.
        minSdkVersion 21
        targetSdkVersion flutter.targetSdkVersion
        versionCode flutterVersionCode.toInteger()
        versionName flutterVersionName
    }

    buildTypes {
        release {
            // TODO: Add your own signing config for the release build.
            // Signing with the debug keys for now, so `flutter run --release` works.
            signingConfig signingConfigs.debug
        }
    }
}

flutter {
    source '../..'
}

dependencies {
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:$kotlin_version"
    implementation platform('com.google.firebase:firebase-bom:31.0.3')
}

Вот мой код регистрации:

onPressed: () async {
  if (nameTextController.text.isEmpty) {
    displayToastMessage(
      "Please enter name", context);
  } else if (nameTextController.text.length < 3) {
    displayToastMessage("Name must be atleast 3 characters", context);
  } else if (nameTextController.text.contains(RegExp(r'[0-9]'))) {
    displayToastMessage("Numbers and special characters cannot be included", context);
  } else if (emailTextController.text.isEmpty) {
    displayToastMessage("Please enter email", context);
  } else if (!emailTextController.text.contains('@')) {
    displayToastMessage("Please enter a valid email", context);
  } else if (passwordTextController.text.isEmpty) {
    displayToastMessage("Please enter password", context);
  } else if (passwordTextController.text.length < 6) {
    displayToastMessage("Password must be at-least 6 Characters", context);
  } else {
    print('Before emailExists');
    emailExists = await UserModel().checkIfEmailExists(email);
    print('Email exist: $emailExists');
    if (emailExists == true) {
    snackBar(context, 'Email is already registered');
    } else {
      /*Move to next screen*/
    }
  }
}

Функция checkIfEmailExist класса модели пользователя

Future<bool> checkIfEmailExists(String email) async {
  try {
    var collectionReference = FirebaseFirestore.instance.collection('users');
    var doc = await collectionReference.doc(email).get();
    return doc.exists;
  } catch (e) {
    rethrow;
  }
}

Пожалуйста, проверьте, включена ли аутентификация -> методы входа (консоль Firebase)

Vinamra Jaiswal 18.11.2022 20:29

@VinamraJaiswal Метод входа по электронной почте/паролю включен. Но какая разница, если аутентификация -> метод входа не включен. Я проверяю электронную почту в базе данных firestore.

Mr Fin 18.11.2022 21:00
Шаблоны Angular PrimeNg
Шаблоны Angular PrimeNg
Как привнести проверку типов в наши шаблоны Angular, использующие компоненты библиотеки PrimeNg, и настроить их отображение с помощью встроенной...
Создайте ползком, похожим на звездные войны, с помощью CSS и Javascript
Создайте ползком, похожим на звездные войны, с помощью CSS и Javascript
Если вы веб-разработчик (или хотите им стать), то вы наверняка гик и вам нравятся "Звездные войны". А как бы вы хотели, чтобы фоном для вашего...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Начала с розового дизайна
Начала с розового дизайна
Pink Design - это система дизайна Appwrite с открытым исходным кодом для создания последовательных и многократно используемых пользовательских...
Шлюз в PHP
Шлюз в PHP
API-шлюз (AG) - это сервер, который действует как единая точка входа для набора микросервисов.
14 Задание: Типы данных и структуры данных Python для DevOps
14 Задание: Типы данных и структуры данных Python для DevOps
проверить тип данных используемой переменной, мы можем просто написать: your_variable=100
0
2
71
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Решение. В правиле базы данных Firestore:

rules_version = '2';
service cloud.firestore {
  match /databases/{database}/documents {
    match /{document=**} {
      allow read, write: if true;
    }
  }
}

Другие вопросы по теме