AWSAmplify(AppSync+Cognito)使用动态组进行每个组织/租户的授权。
创始人
2024-11-19 03:00:23
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 用户池中为每个组织/租户分

相关内容

热门资讯

透视揭露!wepoker辅助脚... 透视揭露!wepoker辅助脚本,wepoker私人局透视-确实是真的有辅助神器(哔哩哔哩)1、下载...
透视科普!wpk透视是真的假的... 透视科普!wpk透视是真的假的,wpk软件是正规的吗-真是存在有辅助软件(哔哩哔哩)1、金币登录送、...
透视解密!wepoker辅助真... 透视解密!wepoker辅助真的假的,We poker辅助器下载-真是真的有辅助神器(哔哩哔哩)亲,...
透视推荐!hhpoker辅助软... 透视推荐!hhpoker辅助软件,hhpoker德州有挂吗-果然是有辅助神器(哔哩哔哩)1、模拟器是...
透视科普!wpk透视是真的假的... 透视科普!wpk透视是真的假的,wpk辅助器是真的吗-真是是真的有辅助攻略(哔哩哔哩)1、有没有辅助...
透视曝光!wepoker可以透... 透视曝光!wepoker可以透视码,wejoker内置辅助-本来有辅助教程(哔哩哔哩)1、该软件可以...
透视揭露!wepoker破解工... 透视揭露!wepoker破解工具,wepoker怎么设置盖牌-本来一直总是有辅助方法(哔哩哔哩)1、...
透视有挂!有哪些免费的wpk作... 透视有挂!有哪些免费的wpk作弊码,wpk辅助器是真的吗-果然一直总是有辅助脚本(哔哩哔哩)1、公共...
透视关于!德扑圈透视挂,德普之... 透视关于!德扑圈透视挂,德普之星透视辅助-好像是真的有辅助软件(哔哩哔哩)脚本下载中分为三种模型:挂...
透视解密!德普辅助器怎么用,德... 透视解密!德普辅助器怎么用,德普之星透视-好像是有辅助app(哔哩哔哩)1、完成辅助器v3.3的残局...