我可以在多个域中使用 Firestore 和 GCP 身份平台吗?

问题描述

我们开发 SaaS 已有一段时间了。

我们决定使用 Google Cloud Identity Platform 来处理 multi-tenant authentication,并使用 firestore 作为我们的主要数据库,但我有一些疑问。

我可以将 Identity Platform 用于多个域和子域吗?

想到这个问题是因为在应用程序中,除了免费子域外,我还允许我的客户连接他们的自定义域,例如:

Client1 将有 client1.com 和 client1.myapp.com

Client2 将有 client2.com 和 client2.myapp.com

但是,我想知道我是否可以以这种方式使用身份平台,是否可行。

我还想知道是否可以使用 Firestore 执行相同的任务,以便我的客户可以从多个域和子域的单个 Firestore 数据库获取数据。

应该注意的是,我们已经配置了在自定义服务器上托管多个域的机制,我们只是想集成 Firestore 和身份平台。

解决方法

您可以在 GCIP 中为每个租户配置一个授权域。有几种方法可以在 Cloud Firestore 中管理多个租户/域。

添加根级域集合

在根级别拆分数据。这意味着您将拥有多个版本的子集合,如果您完全在域/租户内进行查询,这不是问题。但是,您可以使用 collectionGroup 查询来解决此问题。

domains / client1 / users  / user123
                  / mydata / mydata1
domains / client2 / users  / user456
                  / mydata / mydata2

在每个文档中指定域

您可以坚持使用传统的集合结构并将域添加到每个文档。使用此选项时,请记住,每个查询都需要一个索引以允许您的 domainId 字段。

/ users  / user123
/ users  / user456
/ mydata / mydata1
/ mydata / mydata1

每个文档都需要一个 domainId 字段供您过滤。

{
  displayName: 'Bob Smaith',domainId: 'client1'
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...