Подтвердить что ты не робот

Ошибка AWS Cognito: "identityPoolId" не смог удовлетворить ограничение

Я новый Cognito. Я пытаюсь внедрить AWS Cognito, используя Lambda. Это учебник, за которым я следую.

AmazonCognitoIdentityClient client =
                new AmazonCognitoIdentityClient();
    GetOpenIdTokenForDeveloperIdentityRequest tokenRequest = new GetOpenIdTokenForDeveloperIdentityRequest();
    tokenRequest.setIdentityPoolId("us-east-1_XXXXXXX");

Это идентификатор пула, который я использую в файле setIdentityPoolId

введите описание изображения здесь

Это тест JUnit

public class AuthenticateUser implements RequestHandler<Object, Object> {

@Override
public Object handleRequest(Object input, Context context) {

    AuthenticateUserResponse authenticateUserResponse = new AuthenticateUserResponse();
    @SuppressWarnings("unchecked")
    LinkedHashMap inputHashMap = (LinkedHashMap)input;
    User user = authenticateUser(inputHashMap);
    return null;
}

public User authenticateUser(LinkedHashMap input){
    User user = null;
    String userName = (String) input.get("userName");
    String passwordHash = (String) input.get("passwordHash");

    try {
        AmazonDynamoDBClient client = new AmazonDynamoDBClient();
        client.setRegion(Region.getRegion(Regions.US_EAST_1));
        DynamoDBMapper mapper = new DynamoDBMapper(client);
        user = mapper.load(User.class, userName);

        if(user != null){
            System.out.println("user found");
            if(user.getPasswordHash().equals(passwordHash)){
                System.out.println("user password matched");
                String openIdToken = getOpenIdToken(user.getUserId());
                user.setOpenIdToken(openIdToken);
                return user;
            } else {
                System.out.println("password unmatched");
            }
        } else {
            System.out.println("user not found");
        }
    } catch (Exception e) {
        System.out.println("Error: " + e.toString());
    }

    return user; 
}

Это вывод

user found
user password matched

Но я получаю следующую ошибку и, следовательно, оператор return user терпит неудачу

1 validation error detected: Value 'us-east-1_XXXXXX' at 'identityPoolId' 
failed to satisfy constraint: Member must satisfy regular expression pattern: [\w-]+:[0-9a-f-]+ 
(Service: AmazonCognitoIdentity; Status Code: 400; Error Code: ValidationException; 
4b9b3361

Ответ 1

В качестве идентификатора пула идентификаторов используется идентификатор пула пользователей Cognito. Это две разные вещи. Идентификационные идентификаторы пула имеют формат us-east-1: XXXX-XXXXXX-XXXX-XXXX.

Чтобы получить идентификатор пула идентификаторов, вы должны использовать части "Управление федеративными идентификаторами" консоли Cognito, а не раздел "Управление пулами пользователей". Надеюсь, это поможет.