首页 > 解决方案 > 通过 CloudFormation 部署 AWS UserPool 并更新属性

问题描述

如果您通过 CloudFormation 部署 UserPool,例如:

Resources:
  UserPool:
    Type: 'AWS::Cognito::UserPool'
    Properties:
      ...
      Schema:
        - Name: email
          AttributeDataType: String
          Mutable: true
          Required: true

然后更新属性以使其成为name必需:

Schema:
  - Name: email
    AttributeDataType: String
    Mutable: true
    Required: true
  - Name: name
    AttributeDataType: String
    Mutable: true
    Required: true

AWS 认为这name是一个自定义属性并失败:

当前不支持必需的自定义属性。(服务:AWSCognitoIdentityProviderService;状态代码:400;错误代码:InvalidParameterException;请求 ID:...)

这只是一个失败的更新,部署一个干净的堆栈正确地将标准属性emailname标准属性设置为必需。

有没有办法让更新成功?

标签: amazon-web-servicesamazon-cloudformationamazon-cognito

解决方案


不幸的是,这是来自 CloudFormation 的某种错误。与其他问题非常相似,例如更新具有多个索引的 DynamoDB 表。

进行更新的唯一可行方法是分两步进行:

  1. 删除必须更改的属性(在您的情况下name),部署 CloudFormation
  2. 添加具有正确值的属性(因此Require: true在您的情况下添加),部署 CloudFormation

如前所述,有很多与该案例类似的问题,您最好将您的问题发送给 AWS 以获得支持并修复错误。


推荐阅读