教程:通过 Microsoft Entra 权利管理集成来自动执行 ServiceNow 票证创建
方案:在此方案中,你将了解如何使用自定义扩展性和逻辑应用自动生成 ServiceNow 票证,以便手动预配已收到分配且需要访问应用的用户。
在本教程中,学习:
- 将逻辑应用工作流添加到现有目录。
- 将自定义扩展添加到现有访问包中的策略。
- 在 Microsoft Entra ID 中注册应用程序以继续执行权利管理工作流
- 配置 ServiceNow 以进行自动化身份验证。
- 以最终用户身份请求获取访问包。
- 以最终用户身份接收对请求的访问包的访问权限。
先决条件
- 具有活动 Azure 订阅的 Microsoft Entra 用户帐户。 如果还没有帐户,可以免费创建一个帐户。
- 以下角色之一:全局管理员、云应用程序管理员、应用程序管理员或服务主体的所有者。
- Rome 或更高版本的 ServiceNow 实例
- SSO 集成 ServiceNow。 如果尚未配置此项,请参阅:教程:Microsoft Entra 单一登录 (SSO) 与 ServiceNow 集成,然后再继续操作。
注意
建议在完成这些步骤时使用最低特权角色。
将逻辑应用工作流添加到权利管理的现有目录
可将逻辑应用工作流添加到现有目录。 有关如何创建新目录的详细信息,请参阅:在权利管理中创建和管理资源目录。
创建目录后,可以执行以下步骤来添加逻辑应用工作流:
至少以标识治理管理员身份登录到 Microsoft Entra 管理中心。
提示
可以完成此任务的其他最低特权角色包括目录所有者和资源组所有者。
在左侧菜单中,选择“目录”。
选择要为其添加自定义扩展的目录,然后在左侧菜单中选择“自定义扩展”。
在标题导航栏中,选择“添加自定义扩展”。
在“扩展配置”中选择“启动并等待”,将暂停关联的访问包操作,直到与扩展关联的逻辑应用完成其任务且管理员发送恢复操作,然后该过程才会继续。 有关此过程的详细信息,请参阅:配置可暂停权利管理过程的自定义扩展。
在“审阅并创建”中,查看自定义扩展的摘要,确保逻辑应用及其标注的详细信息正确无误。 查看这些详细信息后,选择“创建”。
创建后,即可在自定义扩展页上的自定义扩展旁边的“逻辑应用”下访问该逻辑应用。 你可以在访问包策略中调用该扩展。
提示
若要详细了解可暂停权利管理过程的自定义扩展功能,请参阅:配置可暂停权利管理过程的自定义扩展。
将自定义扩展添加到现有访问包中的策略
在目录中设置自定义扩展性后,管理员可以创建一个访问包以及在请求获得批准后触发自定义扩展的策略。 这样管理员可以定义特定的访问要求,并定制访问评审过程以满足其组织的需求。
在至少以标识治理管理员身份登录的标识治理门户中,选择“访问包”。
提示
可以完成此任务的其他最低特权角色包括目录所有者和访问包管理者。
从已创建的访问包列表中选择要将自定义扩展(逻辑应用)添加到的访问包。
切换到策略选项卡,选择该策略并选择“编辑”。
在策略设置中,转到“自定义扩展”选项卡。
在“阶段”下方的菜单中,选择要用作此自定义扩展(逻辑应用)的触发器的访问包事件。 对于我们的方案,若要在访问包获得批准后触发自定义扩展逻辑应用工作流,请选择“请求被批准”。
注意
若要为之前授予过权限的到期分配创建 ServiceNow 票证,请添加新阶段“分配被删除”,然后选择逻辑应用。
在“自定义扩展”下方的菜单中,选择在上述步骤中创建的要添加到此访问包的自定义扩展(逻辑应用)。 当在“何时”字段中选择的事件发生时,将执行你选择的操作。
注意
如果你希望创建新的访问包,请选择“新建访问包”。 有关如何创建访问包的详细信息,请参阅:在权利管理中创建新的访问包。 有关如何编辑现有访问包的详细信息,请参阅:在 Microsoft Entra 权利管理中更改访问包的请求设置。
在 Microsoft Entra 管理中心内注册带机密的应用程序
提示
本文中的步骤可能因开始使用的门户而略有不同。
借助 Azure,可以使用 Azure Key Vault 来存储应用程序机密,例如密码。 要在 Microsoft Entra 管理中心内注册带机密的应用程序,请执行以下步骤:
至少以标识治理管理员身份登录到 Microsoft Entra 管理中心。
浏览到“标识”>“应用程序”>“应用注册”。
在“管理”下,选择“应用注册”>“新建注册”。
输入应用程序的显示名称。
在支持的帐户类型中选择“仅此组织目录中的帐户”。
选择“注册”。
注册应用程序后,必须按照以下步骤添加客户端密码:
浏览到“标识”>“应用程序”>“应用注册”。
选择你的应用程序。
选择“证书和机密”>“客户端密码”>“新建客户端密码”。
添加客户端机密的说明。
选择机密的过期时间,或指定自定义的生存期。
选择“添加”。
注意
有关注册应用程序的详细信息,请参阅:快速入门:在 Microsoft 标识平台中注册应用:
若要授权创建的应用程序以调用 MS Graph 恢复 API,请执行以下步骤:
导航到 Microsoft Entra 管理中心身份治理 - Microsoft Entra 管理员中心
在左侧菜单中,选择“目录”。
选择为其添加了自定义扩展的目录。
选择“角色和管理员”菜单,然后选择“+ 添加访问包分配管理人员”。
在“选择成员”对话框中,按名称或应用程序标识符搜索创建的应用程序。 选择应用程序,然后选择“选择”按钮。
提示
有关委派和角色的更多详细信息,请参阅以下 Microsoft 官方文档:权利管理中的委托和角色。
配置 ServiceNow 以进行自动化身份验证
此时,可以配置 ServiceNow,以便在 ServiceNow 票证关闭后恢复权利管理工作流:
- 按照以下步骤在 ServiceNow 应用程序注册表中注册 Microsoft Entra 应用程序:
- 按照以下步骤创建系统 Web 服务 REST API 消息:
- 转到“系统 Web 服务”下的“REST API 消息”部分。
- 选择“新建”按钮,创建新的 REST API 消息。
- 填写所有必填字段,其中包括提供终结点 URL:
https://learn.microsoft.com/en-us/graph/api/accesspackageassignmentrequest-resume?view=graph-rest-1.0&tabs=http
- 在“身份验证”中,请选择“OAuth2.0”,然后选择在应用注册过程中创建的 OAuth 配置文件。
- 选择“提交”按钮以保存更改。
- 返回“系统 Web 服务”下的“REST API 消息”部分。
- 选择“Http 请求”,然后选择“新建”。 输入名称,然后选择“POST”作为 Http 方法。
- 在 Http 请求中,使用以下 API 架构添加 Http 查询参数的内容:
{ "data": { "@odata.type": "#microsoft.graph.accessPackageAssignmentRequestCallbackData", "customExtensionStageInstanceDetail": "Resuming-Assignment for user", "customExtensionStageInstanceId": "${StageInstanceId}", "stage": "${Stage}" }, "source": "ServiceNow", "type": "microsoft.graph.accessPackageCustomExtensionStage.${Stage}" }
- 选择“提交”以保存更改。
- 修改请求表架构:若要修改请求表架构,请对下图所示的三个表进行更改: 添加三个列标签并键入为字符串:
- AccessPackageAssignmentRequestId
- AccessPackageAssignmentStage
- StageInstanceId
- 若要使用流设计器自动执行工作流,请执行以下操作:
- 登录 ServiceNow 并转到流设计器。
- 选择“新建”按钮并创建新操作。
- 添加操作以调用在上一步中创建的系统 Web 服务 REST API 消息。
操作的脚本:(使用在上一步中创建的列标签更新脚本):
(function execute(inputs, outputs) { gs.info("AccessPackageAssignmentRequestId: " + inputs['accesspkgassignmentrequestid']); gs.info("StageInstanceId: " + inputs['customextensionstageinstanceid'] ); gs.info("Stage: " + inputs['assignmentstage']); var r = new sn_ws.RESTMessageV2('Resume ELM WorkFlow', 'RESUME'); r.setStringParameterNoEscape('AccessPackageAssignmentRequestId', inputs['accesspkgassignmentrequestid']); r.setStringParameterNoEscape('StageInstanceId', inputs['customextensionstageinstanceid'] ); r.setStringParameterNoEscape('Stage', inputs['assignmentstage']); var response = r.execute(); var responseBody = response.getBody(); var httpStatus = response.getStatusCode(); var requestBody = r.getRequestBody(); gs.info("requestBody: " + requestBody); gs.info("responseBody: " + responseBody); gs.info("httpStatus: " + httpStatus); })(inputs, outputs);
- 保存操作
- 选择“新建”按钮以创建新流。
- 输入流名称,选择“运行方式 - 系统用户”,然后选择“提交”。
- 若要在 ServiceNow 中创建触发器,请执行以下步骤:
以最终用户身份请求获取访问包
当最终用户请求获取访问包时,请求将发送给相应的审批者。 审批者批准后,权利管理会调用逻辑应用。 然后,逻辑应用调用 ServiceNow 创建新的请求/票证,权利管理会等待 ServiceNow 的回调。
以最终用户身份接收对请求的访问包的访问权限
IT 支持团队处理前面创建的票证,以执行必要的预配并关闭 ServiceNow 票证。 当票证关闭时,ServiceNow 会触发调用以恢复权利管理工作流。 请求完成后,请求者将收到权利管理发送的通知,告知请求已完成。 这种简化的工作流可以确保高效地满足访问请求,并及时通知用户。
注意
如果票证未在 14 天内关闭,最终用户将在 MyAccess 门户中看到“分配失败”。
后续步骤
前往下一篇文章,了解创建方法...