AWSAmplify中的Mutation与CognitoUser正常工作,但是查询无法正常工作。
创始人
2024-11-19 02:30:42
0

在为Amplify配置Cognito User Pool时,需要确保read”和“list”操作授权给Authenticated角色。可以通过以下代码实现:

import Amplify, { Auth } from 'aws-amplify'

Amplify.configure({
  Auth: {
    identityPoolId: 'IDENTITY_POOL_ID',
    region: 'REGION',
    userPoolId: 'USER_POOL_ID',
    userPoolWebClientId: 'USER_POOL_WEB_CLIENT_ID',
    mandatorySignIn: true,
    authenticationFlowType: 'USER_PASSWORD_AUTH'
  },
  Storage: { ... },
  API: { ... }
})

// 授权查询操作给Authenticated角色
const user = await Auth.currentAuthenticatedUser()
const credentials = await Auth.currentCredentials()
const { accessKeyId, secretAccessKey, sessionToken } = credentials
const operation = 'cognito-idp:ListUsers'
const params = {
  UserPoolId: 'USER_POOL_ID',
  AttributesToGet: ['email', 'phone_number', 'custom:foo', 'custom:bar']
}
AWS.config.update({
  accessKeyId,
  secretAccessKey,
  sessionToken,
  region: 'REGION'
})
const cognitoClient = new AWS.CognitoIdentityServiceProvider()
const result = await cognitoClient.adminInitiateAuth({
  UserPoolId: 'USER_POOL_ID',
  ClientId: 'USER_POOL_WEB_CLIENT_ID',
  AuthFlow: 'ADMIN_USER_PASSWORD_AUTH',
  AuthParameters: {
    USERNAME: user.username,
    PASSWORD: 'PASSWORD'
  }
}).promise()
const session = result.Session
const response = await cognitoClient.adminRespondToAuthChallenge({
  UserPoolId: 'USER_POOL_ID',
  ClientId: 'USER_POOL_WEB_CLIENT_ID',
  ChallengeName: 'NEW_PASSWORD_REQUIRED',
  Session: session,
  ChallengeResponses: {
    USERNAME: user.username,
    NEW_PASSWORD: 'NEW_PASSWORD'
  }
}).promise()
const accessToken = response.AuthenticationResult.AccessToken
const response = await cognitoClient.createAuthChallenge({
  AccessToken: accessToken,
  ClientId: 'USER_POOL_WEB_CLIENT_ID',
  ChallengeName: operation,
  Session: session,
  // 添加其他查询参数
}).promise()
console.log(response)

需要注意的是,在示例中,认证流程使用了“ADMIN_USER_PASSWORD_AUTH”。如果你的应用程序的认证流程不同,请根据实际情况更改。

另外,示例中的查询操作是“cognito-idp:ListUsers”。如果你需要查询特定的对象,请使用相应的操作名称。

相关内容

热门资讯

2026版辅助挂!黑科技软件大... 2026版辅助挂!黑科技软件大全(辅助)竟然真的是有辅助攻略(真实有挂)1、黑科技软件大全模拟器是什...
2026版技巧!大众互娱脚本(... 2026版技巧!大众互娱脚本(辅助)切实存在有辅助神器(有挂解惑)1、大众互娱脚本免费脚本咨询教程、...
近日!边锋嘉兴辅助(辅助)切实... 近日!边锋嘉兴辅助(辅助)切实是真的有辅助脚本(有挂规律)所有人都在同一条线上,像星星一样排成一排,...
一直以来!上饶窝龙辅助(辅助)... 一直以来!上饶窝龙辅助(辅助)切实真的是有辅助技巧(有挂分享)1、许多玩家不知道上饶窝龙辅助辅助怎么...
明白辅助挂!开心斗一番破解版(... 明白辅助挂!开心斗一番破解版(辅助)总是真的是有辅助插件(有挂教学)1、在开心斗一番破解版插件功能辅...
无独有偶!花花生活圈怎么开挂(... 无独有偶!花花生活圈怎么开挂(辅助)果然存在有辅助神器(竟然有挂)该软件可以轻松地帮助玩家将花花生活...
2026版软件!山西扣点免费辅... 2026版软件!山西扣点免费辅助(辅助)本来存在有辅助脚本(详细教程)暗藏猫腻,小编详细说明山西扣点...
黑科技攻略!悟空大厅辅助(辅助... 黑科技攻略!悟空大厅辅助(辅助)切实真的是有辅助攻略(真的有挂);1、不需要AI权限,帮助你快速的进...
2026版总结!微信小程序辅助... 2026版总结!微信小程序辅助新天道辅助(辅助)一直是有辅助技巧(有挂功能)1、点击下载安装,微信小...
第三方辅助挂!三哥玩辅助器软件... 第三方辅助挂!三哥玩辅助器软件(辅助)果然是真的有辅助软件(有挂教学)1)三哥玩辅助器软件辅助插件:...