我们正在为一个应用程序编写一个 SCIM 提供程序,它适用于 Azure AD。该代码已使用 Microsoft.SystemForCrossDomainIdentityManagement 实现。
我们正在尝试支持 oneLogin 并且创建工作正常,但是在测试更新功能时它失败了,因为 Id 仅在请求中而不在正文中。
public class MyProvider : ProviderBase, IProvider
{
public override Task<Resource> ReplaceAsync(Resource resource, string correlationIdentifier)
{
switch (resource)
{
case Core2User user:
var existingUser = GetUser(applicationId, user.Identifier);
}
}
}
因此,该方法对 ID 没有任何想法,并且由于 user.Identifier 为空而失败。
我试图在他们网站上的文档之后在 schima 中添加 id,但 id 实际上是他们的 id,而不是我们传递给他们的那个。
{"schemas":["urn:ietf:params:scim:schemas:core:2.0:User"],
"active": "{$user.status}",
"emails": {
"value": "{$user.email}",
"type": "work",
"primary": true
},
"userName":"{$parameters.scimusername}",
"id": "{$user.id}",
"name": {
"givenName": "{$user.firstname}",
"familyName": "{$user.lastname}",
"formatted": "{$user.display_name}"
}
}
如何解决这个问题?