- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我创建了一个 Migrate User Lambda 函数并将其连接到我的 AWS Cognito 托管 UI。 lambda 被调用,我在 CloudWatch 日志中看到我的日志语句。一切似乎都正常,只是托管的 UI 似乎没有按预期运行。这几乎就像 Lambda 没有被调用一样,但我知道这是因为我看到了日志语句。托管 UI 始终显示“您输入的用户名或密码无效”,而我希望它将用户带到重置密码工作流程。
我的 Node 功能是:
const https = require('https')
exports.handler = (event, context, callback) => {
if ( event.triggerSource == "UserMigration_Authentication" ) {
LoginUser(event.userName, event.request.password, function(user, message){
console.log("Finished LoginUser call.");
if ( user ) {
console.log("Got a valid user with userId=" + user.userId);
event.response.userAttributes = {
"userName" : user.userName,
"email": user.emailAddress,
"email_verified": "true",
"picture" : user.imageUrl,
"family_name" : user.lastName,
"given_name" : user.firstName,
"custom:userId" : user.userId
};
event.response.finalUserStatus = "RESET_REQUIRED";
event.response.messageAction = "SUPPRESS";
event.response.desiredDeliveryMediums = "EMAIL";
console.log("Done: " + JSON.stringify(event));
//callback(null,event);
context.succeed(event);
}
else {
console.log("User was not found. " + message );
callback(message, event);
}
});
}
else if ( event.triggerSource == "UserMigration_ForgotPassword" ) {
/*
* Check to see if the user exists. If so, then tell cognito
* to proceed, given the email address we looked up.
*/
LookupUser(event.userName, function(user, message){
if ( user ) {
event.response.userAttributes = {
"email": user.emailAddress,
"email_verified": "true"
};
event.response.messageAction = "SUPPRESS";
console.log("Done: " + JSON.stringify(event));
//callback(null,event);
context.succeed(event);
}
else {
callback(message, event);
}
});
}
else {
callback("Bad triggerSource " + event.triggerSource);
}
};
/*
* Lookup a user
*/
function LookupUser(userName, UserCallback) {
var pathUri = "/api/user?op=or&userName=" + encodeURIComponent(userName);
console.log("pathUri=" + pathUri);
var headers = {
"x-k-Id": process.env.kmpzPublicKey,
"x-k-Sig": process.env.kmpzSecretKey
};
var options = {
host: "www.mydomainhere.com",
port: 443,
path: pathUri,
method: "GET",
headers: headers
};
var req = https.request(options, function(res) {
res.on('data', function(data) {
var user = JSON.parse(data);
console.log(user);
if ( user.error ) {
UserCallback(null, user.error.message);
}
else if ( user.userId ) {
UserCallback(user, "OK");
}
else {
UserCallback(null, "Unexpected response from userService. Please contact Kompoz Customer Support.");
}
});
});
req.on('error', function(e) {
UserCallback(null, e.message);
});
req.end();
};
/*
* Login a user
*/
function LoginUser(userName, userPassword, UserCallback) {
var pathUri = "/api/auth/migrate?userName=" + encodeURIComponent(userName) + "&password=" + encodeURIComponent(userPassword);
console.log("pathUri=" + pathUri);
var headers = {
"x-k-Id": process.env.kmpzPublicKey,
"x-k-Sig": process.env.kmpzSecretKey
};
var options = {
host: "www.mydomainhere.com",
port: 443,
path: pathUri,
method: "POST",
headers: headers
};
var req = https.request(options, function(res) {
res.on('data', function(data) {
var user = JSON.parse(data);
console.log(user);
if ( user.error ) {
UserCallback(null, user.error.message);
}
else if ( user.userId ) {
UserCallback(user, "OK");
}
else {
UserCallback(null, "Unexpected response from userService. Please contact Kompoz Customer Support.");
}
});
});
req.on('error', function(e) {
UserCallback(null, e.message);
});
req.end();
};
在 CloudWatch 日志中,我看到了响应:
{
"version": "1",
"triggerSource": "UserMigration_Authentication",
"region": "us-east-1",
"userPoolId": "us-east-1_******",
"userName": "exampleUser",
"callerContext": {
"awsSdkVersion": "aws-sdk-unknown-unknown",
"clientId": "2s12aui53t9a4n85orc3d3ul0u"
},
"request": {
"password": "*******",
"validationData": null,
"userAttributes": null
},
"response": {
"userAttributes": {
"userName": "exampleUser",
"email": "me@example.com",
"email_verified": "true",
"picture": "https://s3.amazonaws.com/example-s3/images/m1006-20140119-033844-p2.jpg",
"family_name": "Smith",
"given_name": "John",
"custom:userId": 1006
},
"forceAliasCreation": null,
"finalUserStatus": "RESET_REQUIRED",
"messageAction": "SUPPRESS",
"desiredDeliveryMediums": "EMAIL"
}
}
最佳答案
希望我能帮忙。只是在这里说“我也是”。您收到 HTTP/401 错误吗?我的 lambda 也在运行,但我无法跳过错误消息。 cloudwatch 中没有日志,cloudtrail 中没有提示。
Request URL: https://******.auth.us-west-2.amazoncognito.com/login?response_type=code&client_id=**************************&redirect_uri=https://local.******.com/auth/login
Request Method: GET
Status Code: 401
Remote Address: 54.191.35.239:443
Referrer Policy: no-referrer-when-downgrade
cache-control: private
content-language: en-US
content-type: text/html;charset=UTF-8
date: Mon, 02 Sep 2019 04:45:17 GMT
expires: Thu, 01 Jan 1970 00:00:00 UTC
server: Server
set-cookie: cognito-fl="W10="; Version=1; Path=/; Secure; HttpOnly
status: 401
strict-transport-security: max-age=31536000 ; includeSubDomains
x-amz-cognito-request-id: 18e6f6e5-6c85-4280-81ac-b90428d66202
x-application-context: application:prod:8443
x-content-type-options: nosniff
x-frame-options: DENY
x-xss-protection: 1; mode=block
:authority: ******.auth.us-west-2.amazoncognito.com
:method: GET
:path: /login?response_type=code&client_id=************************&redirect_uri=https://local.******.com/auth/login
:scheme: https
accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3
accept-encoding: gzip, deflate, br
accept-language: en-US,en;q=0.9
cache-control: no-cache
cookie: XSRF-TOKEN=b4c1c540-6eac-4309-bd81-1ce3cc54e259; cognito-fl="W3sidGFyZ2V0UmVxdWVzdFBhdGgiOiIvbG9naW4iLCJtYXAiOnsibG9naW5FcnJvck1lc3NhZ2UiOiJUaGUgdXNlcm5hbWUgb3IgcGFzc3dvcmQgeW91IGVudGVyZWQgaXMgaW52YWxpZCJ9fV0="
dnt: 1
pragma: no-cache
referer: https://******.auth.us-west-2.amazoncognito.com/login?response_type=code&client_id=***********************&redirect_uri=https://local.******.com/auth/login
sec-fetch-mode: navigate
sec-fetch-site: same-origin
sec-fetch-user: ?1
upgrade-insecure-requests: 1
user-agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/76.0.3809.132 Safari/537.36
response_type: code
client_id: ****************
redirect_uri: https://local.******.com/auth/login
{
"version": "1",
"triggerSource": "UserMigration_Authentication",
"region": "us-west-2",
"userPoolId": "us-west-2_KIcLJftsn",
"userName": "eflyerman@gmail.com",
"callerContext": {
"awsSdkVersion": "aws-sdk-unknown-unknown",
"clientId": "**********************"
},
"request": {
"password": "*********",
"validationData": null,
"userAttributes": null
},
"response": {
"userAttributes": {
"email_verified": true,
"phone_number": "281******",
"given_name": "E***e",
"middle_name": "",
"family_name": "S*****",
"custom:role": "doctor|admin|",
"custom:user_id": 528
},
"forceAliasCreation": null,
"finalUserStatus": "CONFIRMED",
"messageAction": "SUPPRESS",
"desiredDeliveryMediums": "EMAIL"
}
}
关于node.js - AWS Cognito Migrate 用户 Node.js Lambda 函数已调用但未按预期运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57502338/
因此,我正在使用 rails(ruby 1.9.3p392、rails 3.2、sqlite3 db)并尝试将无处不在的博客教程代码部署到“生产”服务器(apache、passenger、ubuntu
我继承了一个项目,该项目设置为使用 Entity Framework 在新数据库上设置数据库架构。 该项目最初有两个不同的文件夹——默认的/Migrations 文件夹和另一个文件夹——带有 DbMi
我在我的 Nest 应用程序上运行这行代码: import * as typeOrm from "../node_modules/typeorm/index"; bootstrap(){ //
我需要像下面的代码一样创建一个外键: Create.ForeignKey().FromTable("TCGDocFiscalOpMedItem").ForeignColumn("IDCabecalho
如何从扩展 Migration 的类的 Up(或 Down)方法中获取迁移正在操作的数据库的名称 public class BaseMigration : Migration { public
我们已将迁移添加到我们的xamarin表单项目中,此后我们就无法将其部署到iOS设备上。它可以在模拟器上正常运行,但在部署到设备时会因AOT错误而失败。 这似乎是一个在网络上广泛传播的话题,但是到目前
我正在尝试自己研究 Fluent Migrator,但我遇到了一个问题,我需要更改由 Fluent Migrator 创建的表的结构,这意味着我使用以下代码创建了一个名为 user 的表 [Migr
我正在使用 PostgreSQL、Rails 3.1.3 和 Ruby 1.9.3。我正在努力使用 db:migrate 概述 here . 这是我在终端中看到的: funkdified@funkdi
我决定使用 gorm作为我的 ORM。我想使用 golang-migrate/migrate 进行迁移因为,看起来 GORM 没有版本化迁移文件。我宁愿使用 CLI 进行迁移,而不是使用自动迁移。 我
我正在针对现有 SQL Server 数据库设置 EF Core 3.1.3 迁移。 这是我到目前为止所做的: 从现有数据库搭建我的模型。 添加 InitialCreate 迁移。 删除 Initia
我正在玩 Entity Framework 和持续构建。到目前为止,通过使用 migrate.exe 和适当的参数,我能够毫无问题地运行迁移或一系列迁移。 但是,我在尝试让 migrate.exe 踢
我正在使用包管理器控制台向我的数据库添加迁移,但由于某种原因它只是卡住并且什么也不做。停止它并继续使用它的唯一方法是使用任务管理器关闭 Visual Studio。这是一个已知问题吗? 最佳答案 我不
我在sequelize上运行帮助命令,发现有两个不同的命令具有相同的描述: $ sequelize help:migration:create Sequelize [Node: 6.9.5, CLI:
在这里,我使用的是 Microsoft Azure。 其中,我正在尝试使用开源 DocumentDB 数据迁移工具将数据从各种来源导入 Microsoft Azure DocumentDB,包括 JS
我是 Laravel 的新手。 我正在开发 Laravel 版本 6。 我已经创建了迁移。 第一次运行良好,但如果我更改迁移文件中的某些内容,然后运行 php artisan migrate它显示
我已经使用 NuGet 安装了 Migrator.NET,但是当我尝试使用 MSBuild 运行迁移时,出现以下错误。我看到它在访问 Migrator.Framework 程序集时遇到问题,但我不确定
我有一个基于 miguel flask tutorial 的网络应用程序 所以我将 sqlalchemy-migrate 用于数据库,现在我应该在迁移中使用 Alembic 我该如何配置?有什么方法可
我已经尝试执行 cli 命令 ./doctrine generate-migrations-diff 并在正确的文件夹中正确创建了一个版本文件。 消息是:generate-migrations-dif
可以定义存储迁移的多个路径: doctrine_migrations.yaml doctrine_migrations: migrations_paths: 'App\Migr
我在我的 .Net 应用程序中使用 Fluent Migrator 1.6.2。 对于数据库的上迁移或下迁移,需要通过命令行传递汇编文件(迁移类所在的数据库工程的dll文件)来执行Migrate.ex
我是一名优秀的程序员,十分优秀!