Azure服务主体创建-使用Azure功能

时间:2020-09-24 16:48:18

标签: python azure azure-functions azure-service-principal

我正在尝试编写Python Azure函数来创建具有自定义角色的服务主体。我有JSON模板来传递角色定义和创建自定义角色。 该功能的想法是使用与“ az ad sp create-for-rbac” cli命令等效的REST API并生成client_id,client_secret和tenant_id。如果您尝试过此方法,请告诉我,非常感谢您的帮助!

import logging
  
import azure.functions as func


def main(req: func.HttpRequest) -> func.HttpResponse:
    logging.info('Python HTTP trigger function processed a request.')

    name = req.params.get('name')
    if not name:
        try:
            req_body = req.get_json()
        except ValueError:
            pass
        else:
            name = req_body.get('name')

    if name:
        return func.HttpResponse(f"Hello, {name}. This HTTP triggered function executed successfully.")
    else:
        return func.HttpResponse(
             "This HTTP triggered function executed successfully. Pass a name in the query string or in the request body for a personalized response.",
             status_code=200
        )

1 个答案:

答案 0 :(得分:0)

您有两个选择:

  1. 利用Microsoft Graph API创建和管理您的应用用户。不幸的是,目前没有适用于Python的SDK,因此您需要自己通过API调用进行设置。
  2. 更简单,但不推荐。使用Azure SDK for Python中的GraphRbacManagementClient类。库中有专门用于执行此操作的方法(这就是the CLI currently uses)。但是,我们不再开发Azure Graph API,建议迁移到Microsoft Graph API。