gpt4 book ai didi

java - 在 JWT 用户映射期间创建 Gentics Mesh 用户配置文件节点 - 导致失败

转载 作者:行者123 更新时间:2023-11-30 05:25:34 24 4
gpt4 key购买 nike

我正在开发一个身份验证插件,它使用 JWT 解析来获取详细信息并更新 Mesh 中的用户。
我还想创建一个新节点并将其附加到网格中的用户,使用 user.setNodeReference()//这是我将用户关联到节点的方式吗?

问题是,当我返回映射结果时,如果我创建用户配置文件节点,我会看到使用与之前相同的 token 再次调用 mapToken() 方法,就像它在循环一样。 我发现这是由于路由器中的“重试”功能

如果我没有将节点附加到user.nodeReference(),那么它会按预期进行。

想法?

    @Override
public MappingResult mapToken(HttpServerRequest req, String uuid, JsonObject token) {
MappingResult result = new MappingResult();

if (uuid == null) {
log.info("First time login of the user");
} else {
log.info("Already synced user is logging in.");
}

log.info("Mapping user in plugin");
printToken(token);
String username = extractUsername(token).get();
UserUpdateRequest user = new UserUpdateRequest();
user.setUsername(username);
user.setEmailAddress(username);
user.setFirstname(token.getString("firstname", "firstname"));
user.setLastname(token.getString("lastname", "lastname"));

// TODO: Stop the infinite loop
if (uuid == null) {
log.info("Creating profile node");
user.setNodeReference(createProfileNode(username, token));
} else {
log.info("Updating profile node");
//updateProfileNode(uuid, token);
}

result.setUser(user);

...
}

private ExpandableNode createProfileNode(String username, JsonObject token) {

NodeCreateRequest nodeCreateRequest = new NodeCreateRequest()
.setLanguage("en")
.setSchemaName(getConfig().getProfileSchema())
.setParentNodeUuid(getConfig().getProfileParentUuid());
FieldMap fields = nodeCreateRequest.getFields();
fields.putString("name", username);
fillProfileFieldMappedValues(fields, token);
nodeCreateRequest.setFields(fields);
return this.adminClient.createNode(getConfig().getProjectName(), nodeCreateRequest).blockingGet();
}

更新

我检查了 jti 和 iat - token 包含两者。
我想也许如果我订阅 USER_CREATED 事件,我可以在创建用户后添加一个配置文件节点。
但我没有看到这被执行过。我可能错误地订阅了本地事件总线。

getRxVertx().eventBus().localConsumer(MeshEvent.USER_CREATED.getAddress()).handler((message) -> {
try {
String uuid = JsonUtil.getMapper().readTree(message.body().toString()).get("uuid").asText();
adminClient().findUserByUuid(uuid).toSingle().doAfterSuccess(u -> {
u.setNodeReference(createProfileNode(u.getUuid()).getBody());
}).doOnError(e -> {
log.error("Failed to create user profile node: {}", e);
});
} catch (IOException e) {
log.error("Failed to deserialize user: {}", e);
}
});

此外,我不需要设置 user.setNodeReference() 来重现错误,我只需要尝试在 mapToken 方法中创建一个新节点。它将重试创建用户 10 次,然后出现 http 500 错误。
我将打开日志记录以查看是否可以获得更多详细信息。

更新我发现,如果我首先在 mapToken 函数中创建用户,然后为配置文件创建一个节点,我可以将其添加到 user.setNodeReference() 但我从未在内容浏览器中看到该节点[我在“{project}/profiles/{userProfileNode}”中创建它],并且在检索用户时无法看到节点引用。

但是日志显示节点创建成功。

最佳答案

您的 token 是否包含 token ID? (jti 或 iat)。 Mesh 将使用这些值之一来确定是否需要为 token 重新运行键映射。其背后的想法是避免对未更改的 token 进行虚假映射调用。我怀疑您的 token 没有通过此检查,并且将始终传递给映射器插件。

如果我能看到一些日志,我也许可以给你更多提示。

关于java - 在 JWT 用户映射期间创建 Gentics Mesh 用户配置文件节点 - 导致失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58702751/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com