Отправка сообщения от триггеров Cognito - PullRequest
1 голос
/ 16 марта 2019

Я хочу ограничить вход пользователей в пользовательский интерфейс, размещенный на Cognito.Я вижу, что есть триггеры, в которых мы можем присоединить лямбду, но всякий раз, когда я изменяю объект события внутри лямбды, вместо того, чтобы получать свое собственное сообщение User exceeded limits, я получаю unrecognizable lambda output ошибку.

Может кто-нибудь помочь мнев этом или есть какой-либо другой способ достижения этой функциональности?

Теперь я получаю это cognito error from trigger

с этим кодом:

exports.handler = (event, context, callback) => {
    if (true) {
        var error = new Error("Cannot signin because your signin count is 5");
        // Return error to Amazon Cognito
        callback(error, event);
    }
    // Return to Amazon Cognito
    callback(null, event);
};

Но я не хочу префикс PreAuthentication failed with error, я просто хочу показать свое сообщение.

Любая помощь приветствуется.

1 Ответ

0 голосов
/ 21 марта 2019

В настоящее время невозможно остановить добавление префикса в Cognito, поскольку форма является размещенным веб-интерфейсом.

Если это сложное требование, обходной путь - создать собственную форму входа и использовать aws-cognito-sdk

Как только вы сделаете вызов cognitoUser.authenticateUser в коде ниже триггера предварительной аутентификации, сработает функция Lambda, и вам нужно будет обработать ошибку и проанализировать ее, чтобы удалить нежелательный префикс.

Надеюсь, это поможет

aws Примеры: использование JavaScript SDK

var authenticationData = {
    Username : 'username',
    Password : 'password',
};
var authenticationDetails = new AmazonCognitoIdentity.AuthenticationDetails(authenticationData);
var poolData = { UserPoolId : 'us-east-1_TcoKGbf7n',
    ClientId : '4pe2usejqcdmhi0a25jp4b5sh3'
};
var userPool = new AmazonCognitoIdentity.CognitoUserPool(poolData);
var userData = {
    Username : 'username',
    Pool : userPool
};
var cognitoUser = new AmazonCognitoIdentity.CognitoUser(userData);
cognitoUser.authenticateUser(authenticationDetails, {
    onSuccess: function (result) {
        var accessToken = result.getAccessToken().getJwtToken();

        /* Use the idToken for Logins Map when Federating User Pools with identity pools or when passing through an Authorization Header to an API Gateway Authorizer*/
        var idToken = result.idToken.jwtToken;
    },

    //Your message from the Lambda will return here, you will need to parse the err to remove the unwanted prefix*
    onFailure: function(err) {

        alert(err);
    },

});
...