AWSAmplify(AppSync+Cognito)使用动态组进行每个组织/租户的授权。
创始人
2024-11-19 03:01:30
0
  1. 创建 Cognito 用户池和用户组 首先我们需要创建一个 Cognito 用户池,并为每个组织/租户创建一个用户组。以以下代码片段为例:
const cognito = new AWS.CognitoIdentityServiceProvider();

const createUserGroup = async (groupName) => {
  const params = {
    GroupName: groupName,
    UserPoolId: ""
  };
  return cognito.createGroup(params).promise();
};

const createOrganizationGroups = async (organizationList) => {
  for (const org of organizationList) {
    await createUserGroup(org.groupName);
  }
};

const organizationList = [
  { groupName: "OrgA" },
  { groupName: "OrgB" }
];

await createOrganizationGroups(organizationList);

这段代码会创建两个 Cognito 用户组,组名分别为 "OrgA" 和 "OrgB"。

  1. 集成 Cognito 用户池到 Amplify 将 Cognito 用户池集成到 Amplify 以便在客户端中进行身份验证。在项目目录下,使用以下命令将 Amplify 添加到您的项目中:
amplify init

接下来,执行以下命令以添加 Cognito 用户池:

amplify add auth

选择 "Cognito" 作为身份验证服务,并按照向导进行配置。

  1. 创建 AppSync GraphQL API 使用以下命令创建 AppSync GraphQL API:
amplify add api

选择 "GraphQL" 作为 API 类型,选择已添加的 Cognito 用户池并选择'当前用户”作为身份验证类型。

  1. 使用 AppSync 数据源进行授权 AppSync 的数据源可以使用 DynamoDB 表、Lambda 函数、HTTP 数据源等。于是,我们可以在 AppSync 的数据源上配置动态组授权,以提供每个组织/租户所需的数据保护。为了使用动态组授权,需要执行以下操作:
  • 为每个组织/租户创建一个自定义字段,该字段可以识别该组织。
  • 将该字段添加到 AppSync 数据源的请求头中,可以在请求头中使用 '$context.identity.claims.” 访问该字段。
  • 在 Cognito 用户池中为每个组织/租户分

相关内容

热门资讯

安卓换鸿蒙系统会卡吗,体验流畅... 最近手机圈可是热闹非凡呢!不少安卓用户都在议论纷纷,说鸿蒙系统要来啦!那么,安卓手机换上鸿蒙系统后,...
安卓系统拦截短信在哪,安卓系统... 你是不是也遇到了这种情况:手机里突然冒出了很多垃圾短信,烦不胜烦?别急,今天就来教你怎么在安卓系统里...
app安卓系统登录不了,解锁登... 最近是不是你也遇到了这样的烦恼:手机里那个心爱的APP,突然就登录不上了?别急,让我来帮你一步步排查...
安卓系统要维护多久,安卓系统维... 你有没有想过,你的安卓手机里那个陪伴你度过了无数日夜的安卓系统,它究竟要陪伴你多久呢?这个问题,估计...
windows官网系统多少钱 Windows官网系统价格一览:了解正版Windows的购买成本Windows 11官方价格解析微软...
安卓系统如何卸载app,轻松掌... 手机里的App越来越多,是不是感觉内存不够用了?别急,今天就来教你怎么轻松卸载安卓系统里的App,让...
怎么复制照片安卓系统,操作步骤... 亲爱的手机控们,是不是有时候想把自己的手机照片分享给朋友,或者备份到电脑上呢?别急,今天就来教你怎么...
安卓系统应用怎么重装,安卓应用... 手机里的安卓应用突然罢工了,是不是让你头疼不已?别急,今天就来手把手教你如何重装安卓系统应用,让你的...
iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
iphone系统与安卓系统更新... 最近是不是你也遇到了这样的烦恼?手机更新系统总是失败,急得你团团转。别急,今天就来给你揭秘为什么iP...