- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Firebase 身份验证和 Cloud Firestore 构建基于权限的身份验证系统,但我在登录时无法检查用户文档。该应用程序是使用 Angular 6 和 angularfire2 构建的。
想法是,一旦用户登录,应用程序将检查是否已为用户创建用户文档。如果没有,它将创建一个用户文档并在其中填充默认权限和用户信息。
这是我的代码和我试过的两个函数:
import { Injectable } from '@angular/core';
import { User } from './../models/user.model';
import { PermissionsService } from './permissions.service';
import { auth } from 'firebase/app';
import { AngularFireAuth } from 'angularfire2/auth';
import {
AngularFirestore,
AngularFirestoreDocument,
AngularFirestoreCollection,
} from 'angularfire2/firestore';
import { Observable, of } from 'rxjs';
import { switchMap } from 'rxjs/operators';
@Injectable({
providedIn: 'root',
})
export class AuthService {
usersCollection = null;
user: Observable<User>;
constructor(
private afAuth: AngularFireAuth,
private db: AngularFirestore,
private permissionsService: PermissionsService,
) {
this.usersCollection = db.collection('users');
this.user = this.afAuth.authState.pipe(
switchMap((user) => {
if (user) {
return this.db
.doc<User>(`users/${user.uid}`)
.valueChanges();
} else {
return of(null);
}
}),
);
}
loginGoogle() {
const provider = new auth.GoogleAuthProvider();
return this.oAuthLogin(provider);
}
loginFacebook() {
const provider = new auth.FacebookAuthProvider();
return this.oAuthLogin(provider);
}
loginTwitter() {
const provider = new auth.TwitterAuthProvider();
return this.oAuthLogin(provider);
}
oAuthLogin(provider) {
return this.afAuth.auth.signInWithPopup(provider).then((credential) => {
// My first attempt using .where to find a doc with matching email
// This gives an error saying .where() does not exist
const docExists = this.usersCollection.where(
'email',
'==',
credential.user.email,
);
if (docExists) {
console.log('User logged in');
} else {
console.log('user does not exist');
this.createUser(credential.user);
}
//My second attempt using .get() to find a doc with matching uid
//The id of the doc matches the uid of the auth user by design
//This gives an error saying .get() does not exist
// this.usersCollection
// .doc(credential.user.uid)
// .get()
// .then((docSnapshot) => {
// if (docSnapshot.exists) {
// console.log('User logged in');
// } else {
// console.log('user does not exist');
// this.createUser(credential.user);
// }
// });
});
}
createUser(user) {
console.log('creating user');
const newUser: User = {
uid: user.uid,
email: user.email,
photoURL: user.photoURL,
displayName: user.displayName,
roles: {
member: true,
},
permissions: this.permissionsService.memberPermissions,
};
this.usersCollection
.add(newUser)
.then((docRef) => {
console.log('added new user');
newUser.uid = docRef.id;
docRef.set(newUser);
})
.catch((err) => {
console.log('Error adding user: ' + err);
});
}
logout() {
this.afAuth.auth.signOut();
this.user = null;
}
}
这里是抛出的错误:
zone.js:192 Uncaught TypeError: _this.usersCollection.where is not a function
和
zone.js:192 Uncaught TypeError: _this.usersCollection.doc(...).get is not a function
我是 firebase 的新手,尤其是 Firestore 的新手(我想每个人都是),我在 angularfire2 或 firebase 的文档中找不到任何可以说明我为什么不能这样做的内容。
请帮助我理解为什么这些函数被视为无效。
此外,如果您对我如何以更好的方式处理整个身份验证过程有任何提示或意见,请随时添加评论。这是我第一次尝试创建这样的身份验证服务。
最佳答案
// This gives an error saying .where() does not exist:
那是因为 .where()
在类型 AngularFirestoreCollection
上不存在.您正在通过 this.usersCollection = db.collection('users')
对其进行评估在构造函数中。
可以这样查询一个集合:
const docExists = this.afs.collection<User[]>('users', ref => ref.where('email', '==', credential.user.email));
但这并不能解决您的问题。在之前的声明中,docExist
也将是一个 AngularFirestoreCollection
,并检查 if (docExists) {
永远是真的。因此,您要寻找的是一种基于查询检查文档是否存在的方法:
private oAuthLogin(provider: any) {
return this.afAuth.auth
.signInWithPopup(provider)
.then(credential => {
const usersCollection = this.afs.collection<User[]>('users', ref => ref.where('email', '==', credential.user.email));
const users = usersCollection.snapshotChanges()
.pipe(
map(actions => {
return actions.map(action => {
const data = action.payload.doc.data();
const id = action.payload.doc.id;
return { id, ...data };
});
}),
take(1));
users.subscribe(snap => {
if (snap.length === 0) {
console.log('user does not exist');
this.createUser(credential.user);
} else {
console.log('User logged in');
}
});
});
}
关于javascript - Cloud Firestore 文档 .get() 和 .where() 函数无法识别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51865263/
我正在尝试为我的 Firestore 设置一个数据库,但是我尝试重新安装 pod 和许多其他东西,但我仍然无法让它工作,因为它显示了这个错误: Type 'Firestore' has no memb
我需要更改我的项目 ID,因为要验证的 Firebase 身份验证链接在链接上显示了项目 ID,并且由于品牌 reshape ,项目名称已更改。根据我发现的信息,更改项目 ID 似乎不太可能。我正在考
快速提问。长话短说,我在我的谷歌云功能日志中收到此错误: Firestore (4.10.1):无法到达 Firestore 后端。 这是我的函数文件中的代码: // pull in firebas
我正在从事 Angular 6 项目。这是我使用 --prod 构建时遇到的错误标记、主持和运行。我已经坐了很长时间了。最初认为这可能是 firestore 包的问题,我等了。但是现在更新到fir
我正在开发一个 React 项目,这是我的第一个 React 项目。此代码部署成功。但在使用 postman 测试时出现一些错误。我“发布”“createScream”函数的 URL 并发送它。然后我
我有一个包含两个集合的 Firestore 数据库:用户和锦标赛。用户具有“参与者”角色和“管理员”角色,并在用户文档中由“isParticipant”和“isAdmin” bool 值指示: /us
Firebase 数据库根据他们的文档提供了 10 MB 的离线数据库缓存限制,但没有提到 的离线数据限制。 Firestore 数据库。 Firestore 的离线数据保存限制是多少? 最佳答案 根
我正在尝试评估 string在 Firestore 安全规则 基于 matches正则表达式功能 我的代码是 username.matches('^(?!\.)(?!_)(?!.*\.$)(?!.*?
是否可以在 Firestore 中定义具有唯一约束的索引?如果没有,如何在文档字段上强制执行唯一性(不使用文档 ID)? 最佳答案 是的,这可以通过结合使用两个集合、Firestore 规则和批量写入
我正在学习 GCP,在他们的 Firestore 中,我对 Admin.firestore 和 Firebase.firestore 的区别感到困惑。 这是管理员的代码: const admin =
使用带有自定义声明的 firestore 在线安全模拟会导致错误,但它在部署时可以完美运行(同时实际处理真实请求)。错误是: Error: simulator.rules line [5], colu
所以,我知道有一些类似命名的问题,但这是不一样的。 我很想知道是否有人可以解释缺少 increment 的原因。哨兵,类似于delete一。 据我所知,字段删除与文档更新没有什么不同。意思是,我只能
我想创建两个带有分页选项的查询。在第一个记录中,我想获取前十条记录,在第二个记录中,我想获取其他所有记录: .startAt(0) .limit(10) .startAt(9) .limit(null
我正在努力为我的应用寻找最佳架构。我应该使用顶级集合、子集合、数组等吗? 设置: 我的应用程序将有许多用户将参与的测验。 每个测验都会有多个问题。 每个问题都有多个答案,只能选择一个。 每个用户只能回
我正在努力为我的应用寻找最佳架构。我应该使用顶级集合、子集合、数组等吗? 设置: 我的应用程序将有许多用户将参与的测验。 每个测验都会有多个问题。 每个问题都有多个答案,只能选择一个。 每个用户只能回
我无法在任何地方找到我可以在一个Collection中获得的文档数量的限制。假设我有1,000,000,000个文档...那有可能吗?如果我想把它们全部都拿走,实际上会给我十亿吗? 最佳答案 可以存储
假设我有一个集合 mycollection有 1,000,000 条记录。 此查询将返回多少条记录? const query = firestore.collection('mycollection'
这是错误消息:@firebase/firestore: Firestore (4.12.1): Could not reach Firestore backend 我正在构建一个网络应用程序,它今天运
我在编写和测试我的 Firestore 规则时遇到了一个奇怪的问题。这是我想要实现的目标: 当应用程序启动时,用户会匿名登录。这用户开始新游戏。 我创建了一个基本上只包含时间戳的“ session ”
我是云函数的新手。我有一些困惑。 admin.firestore 和functions.firestore? admin.database 是实时数据库吗? 因此,如果云函数基本上是用 JavaScr
我是一名优秀的程序员,十分优秀!