Без сервера: [AWS] Невозможно создать ресурс роли с политикой - PullRequest
0 голосов
/ 17 мая 2019

Я изучаю, как использовать серверную среду, и я нахожусь на стадии создания ролей, которые будут выполнять некоторые конкретные функции, но облачная информация выдает ошибку, указывающую:

An error occurred: LambdaAdminRole - Unknown field Policies (Service: AmazonIdentityManagement; Status Code: 400; Error Code: MalformedPolicyDocument; Request ID: 07cb3916-78c5-11e9-b0f6-37c9c6cd9547).

Способ определения ресурса в безсерверном режиме выглядит следующим образом:

resources:
  Resources:
    LambdaAdminRole:
      Type: AWS::IAM::Role
      Properties:
        RoleName: ${self:service}-${self:provider.stage}-lambda-admin-role
        AssumeRolePolicyDocument:
          Version: '2017'
          Statement:
            - Effect: Allow
              Principal:
                Service:
                  - lambda.amazonaws.com
              Action: sts:AssumeRole
          Policies:
            - PolicyName: ${self:service}-${self:provider.stage}-lambda-cognito-admin-policy
              PolicyDocument:
                Version: '2017'
                Statement:
                  - Effect: Allow
                    Action:
                      - cognito-idp:ListUsersInGroup
                      - cognito-idp:ListUsers
                    Resource:
                      - 'Fn::Join':
                          - ':'
                          - - 'arn:aws:cognito-idp'
                            - ${self:provider.region}
                            - Ref: 'AWS::AccountId'
                            - 'userpool/*'

Разве это не правильный способ создания роли с помощью serverless? Я следовал примерам, которые показывают в документации по serverless: https://serverless.com/framework/docs/providers/aws/guide/iam/

Ответы [ 2 ]

2 голосов
/ 17 мая 2019

У вас неверный отступ, атрибут Policies относится к Properties, а не к AssumeRolePolicyDocument, как в вашем документе.

(отступает весь раздел Policies по одному)

0 голосов
/ 19 мая 2019

Как указано в официальной документации Policies принадлежит Properties, а не AssumeRolePolicyDocument

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...