3
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

PowerAutomate: Planner の バケット名を取得する方法

Last updated at Posted at 2022-04-07

背景

Planner を自動化している人からの質問で、バケット名が取れない!って話があったので調べてみた記録

概要

で、その 取得結果 はこんな感じ

image.png

ということで、方針は

  1. バケットID と バケット名 の一覧を用意
  2. 取得したいバケットID に該当するバケット名を取得する

ってことだけど・・
バケット一覧を取得しようとするとある課題が・・

  • グループID
  • プランID

の二つが必要

image.png

で、グループ、プラン、バケットの関係は以下なので、

  • グループ
    • プラン
      • バケット

方針としては

  1. グループ一覧取得
  2. プラン一覧取得
  3. バケット一覧取得
  4. ようやく、バケットID/名前 一覧を作成
  5. 一覧を利用して、バケットIDから名前を取得

詳細

フロー全景

こんな感じで、バケット名が取れます
image.png

それぞれの説明をしていくと・・

バケットID と バケット名 の一覧 の変数初期化

一覧作るので、まずは配列として初期化しておく
image.png

バケットID と バケット名 の一覧 の変数一覧作成

  1. グループ一覧取得
  2. プラン一覧取得
  3. バケット一覧取得
  4. バケットID/名前 一覧を作成

image.png

プラン一覧取得の設定

動的コンテンツで、グループID を渡すだけ
image.png

バケット一覧の取得

こちらも動的コンテンツで、グループID と プランID を渡すだけ
image.png

一覧に、それぞれのバケットID/名前 を紐づけたオブジェクトを追加していく

image.png

これで、あとは、BucketID で拾うだけ

一覧オブジェクト作成
{
  "BucketID": @{items('Apply_to_each_Bucket')?['id']},
  "BucketName": @{items('Apply_to_each_Bucket')?['name']}
}

バケット名取得

image.png

バケットID でのフィルター方法

単純にバケットIDで一致 (equal) するものだけにフィルター
image.png

フィルター条件
@equals(items('Apply_to_each_Task')?['bucketId'], item()['BucketID'])

バケット名を一点だけ取得

最初の一点を取得するだけ
こうしておかないと、参照した際に、リストの展開が勝手に走るので、その予防。
あとは使うだけですね。
image.png

最初の一点取得
@{first(body('Filter_array')).BucketName}

自分で作成した変数である為、動的コンテンツには出てきません。
動的コンテンツで使いたい場合は、JSON解析(Parse JSON) で解析させてやれば、使えます。

関連コネクター一覧

自分が所有および属しているグループを一覧表示する
グループのリストを一覧表示する
バケットの一覧表示

タスクの一覧表示

再現方法

以下のそれぞれの JSON をコピペ利用することで可能。コピペ方法は以下

バケットID と バケット名 の一覧 の変数初期化部分

変数初期化を Scope に含ませられないので、分割してます

一覧用変数
{
    "id": "70194cac-722a-410e-928b-e23626136756",
    "brandColor": "#770BD6",
    "connectionReferences": {
        "shared_office365groups": {
            "connection": {
                "id": "/providers/Microsoft.PowerApps/apis/shared_office365groups/connections/shared-office365grou-c08f06b2-071d-44e3-bb02-62fc623e68ed"
            }
        },
        "shared_planner": {
            "connection": {
                "id": "/providers/Microsoft.PowerApps/apis/shared_planner/connections/shared-planner-9e851f83-d92f-4f9a-a2e5-81121d888066"
            }
        }
    },
    "connectorDisplayName": "Variables",
    "icon": "",
    "isTrigger": false,
    "operationName": "Initialize_variable_Buckets",
    "operationDefinition": {
        "type": "InitializeVariable",
        "inputs": {
            "variables": [
                {
                    "name": "Buckets",
                    "type": "array",
                    "value": []
                }
            ]
        },
        "runAfter": {},
        "metadata": {
            "operationMetadataId": "42d478aa-c3ea-451d-bccd-321304caff6b"
        }
    }
}

残りの全部

フロー全体
{
    "id": "d03606a6-adbf-447d-bee2-42b4d0eee36b",
    "brandColor": "#8C3900",
    "connectionReferences": {
        "shared_office365groups": {
            "connection": {
                "id": "/providers/Microsoft.PowerApps/apis/shared_office365groups/connections/shared-office365grou-c08f06b2-071d-44e3-bb02-62fc623e68ed"
            }
        },
        "shared_planner": {
            "connection": {
                "id": "/providers/Microsoft.PowerApps/apis/shared_planner/connections/shared-planner-9e851f83-d92f-4f9a-a2e5-81121d888066"
            }
        }
    },
    "connectorDisplayName": "Control",
    "icon": "",
    "isTrigger": false,
    "operationName": "Scope",
    "operationDefinition": {
        "type": "Scope",
        "actions": {
            "Scope_Create_Buckets_Name_List": {
                "type": "Scope",
                "actions": {
                    "List_groups_that_I_own_and_belong_to": {
                        "type": "OpenApiConnection",
                        "inputs": {
                            "host": {
                                "connectionName": "shared_office365groups",
                                "operationId": "ListOwnedGroups_V3",
                                "apiId": "/providers/Microsoft.PowerApps/apis/shared_office365groups"
                            },
                            "parameters": {},
                            "authentication": {
                                "type": "Raw",
                                "value": "@json(decodeBase64(triggerOutputs().headers['X-MS-APIM-Tokens']))['$ConnectionKey']"
                            }
                        },
                        "runAfter": {},
                        "metadata": {
                            "operationMetadataId": "f160977d-37f3-44fc-8d62-a2acec6df09f"
                        }
                    },
                    "Apply_to_each_Group": {
                        "type": "Foreach",
                        "foreach": "@outputs('List_groups_that_I_own_and_belong_to')?['body/value']",
                        "actions": {
                            "List_plans_for_a_group": {
                                "type": "OpenApiConnection",
                                "inputs": {
                                    "host": {
                                        "connectionName": "shared_planner",
                                        "operationId": "ListGroupPlans",
                                        "apiId": "/providers/Microsoft.PowerApps/apis/shared_planner"
                                    },
                                    "parameters": {
                                        "groupId": "@items('Apply_to_each_Group')?['id']"
                                    },
                                    "authentication": {
                                        "type": "Raw",
                                        "value": "@json(decodeBase64(triggerOutputs().headers['X-MS-APIM-Tokens']))['$ConnectionKey']"
                                    }
                                },
                                "runAfter": {},
                                "metadata": {
                                    "operationMetadataId": "f6f5e952-fc2d-41bc-9721-576f3d1a8d7b"
                                }
                            },
                            "Apply_to_each_Plan": {
                                "type": "Foreach",
                                "foreach": "@outputs('List_plans_for_a_group')?['body/value']",
                                "actions": {
                                    "List_buckets": {
                                        "type": "OpenApiConnection",
                                        "inputs": {
                                            "host": {
                                                "connectionName": "shared_planner",
                                                "operationId": "ListBuckets_V3",
                                                "apiId": "/providers/Microsoft.PowerApps/apis/shared_planner"
                                            },
                                            "parameters": {
                                                "groupId": "@items('Apply_to_each_Group')?['id']",
                                                "id": "@items('Apply_to_each_Plan')?['id']"
                                            },
                                            "authentication": {
                                                "type": "Raw",
                                                "value": "@json(decodeBase64(triggerOutputs().headers['X-MS-APIM-Tokens']))['$ConnectionKey']"
                                            }
                                        },
                                        "runAfter": {},
                                        "metadata": {
                                            "operationMetadataId": "011459fc-89b5-4da1-91d8-4bb21a74fa91"
                                        }
                                    },
                                    "Apply_to_each_Bucket": {
                                        "type": "Foreach",
                                        "foreach": "@outputs('List_buckets')?['body/value']",
                                        "actions": {
                                            "Append_to_array_variable": {
                                                "type": "AppendToArrayVariable",
                                                "inputs": {
                                                    "name": "Buckets",
                                                    "value": {
                                                        "BucketID": "@items('Apply_to_each_Bucket')?['id']",
                                                        "BucketName": "@items('Apply_to_each_Bucket')?['name']"
                                                    }
                                                },
                                                "runAfter": {},
                                                "metadata": {
                                                    "operationMetadataId": "6a6f440a-761a-43f5-9032-6b675a1d3a26"
                                                }
                                            }
                                        },
                                        "runAfter": {
                                            "List_buckets": [
                                                "Succeeded"
                                            ]
                                        },
                                        "metadata": {
                                            "operationMetadataId": "0423a98d-4e3e-4418-a555-b21075cd6619"
                                        }
                                    }
                                },
                                "runAfter": {
                                    "List_plans_for_a_group": [
                                        "Succeeded"
                                    ]
                                },
                                "metadata": {
                                    "operationMetadataId": "a599c042-bd54-4175-a133-b10603c7bf10"
                                }
                            }
                        },
                        "runAfter": {
                            "List_groups_that_I_own_and_belong_to": [
                                "Succeeded"
                            ]
                        },
                        "metadata": {
                            "operationMetadataId": "bb4a0b17-76b7-4beb-bb2f-a1933ad5a258"
                        }
                    }
                },
                "runAfter": {},
                "metadata": {
                    "operationMetadataId": "3bc94144-d2ea-47d4-ae84-7829eabef01f"
                }
            },
            "Scope_Get_Bucket_Name": {
                "type": "Scope",
                "actions": {
                    "List_my_tasks": {
                        "type": "OpenApiConnection",
                        "inputs": {
                            "host": {
                                "connectionName": "shared_planner",
                                "operationId": "ListMyTasks_V2",
                                "apiId": "/providers/Microsoft.PowerApps/apis/shared_planner"
                            },
                            "parameters": {},
                            "authentication": {
                                "type": "Raw",
                                "value": "@json(decodeBase64(triggerOutputs().headers['X-MS-APIM-Tokens']))['$ConnectionKey']"
                            }
                        },
                        "runAfter": {},
                        "metadata": {
                            "operationMetadataId": "01bfed00-a150-4beb-8ba7-82f924956ac4"
                        }
                    },
                    "Apply_to_each_Task": {
                        "type": "Foreach",
                        "foreach": "@outputs('List_my_tasks')?['body/value']",
                        "actions": {
                            "Get_a_task": {
                                "type": "OpenApiConnection",
                                "inputs": {
                                    "host": {
                                        "connectionName": "shared_planner",
                                        "operationId": "GetTask_V2",
                                        "apiId": "/providers/Microsoft.PowerApps/apis/shared_planner"
                                    },
                                    "parameters": {
                                        "id": "@items('Apply_to_each_Task')?['id']"
                                    },
                                    "authentication": {
                                        "type": "Raw",
                                        "value": "@json(decodeBase64(triggerOutputs().headers['X-MS-APIM-Tokens']))['$ConnectionKey']"
                                    }
                                },
                                "runAfter": {},
                                "metadata": {
                                    "operationMetadataId": "75b1ab60-8a5e-45b8-9b92-de444ce90888"
                                }
                            },
                            "Compose": {
                                "type": "Compose",
                                "inputs": "@first(body('Filter_array')).BucketName",
                                "runAfter": {
                                    "Filter_array": [
                                        "Succeeded"
                                    ]
                                },
                                "metadata": {
                                    "operationMetadataId": "58a0fca4-a11c-4111-85ca-6dac3e80b360"
                                }
                            },
                            "Filter_array": {
                                "type": "Query",
                                "inputs": {
                                    "from": "@variables('Buckets')",
                                    "where": "@equals(outputs('Get_a_task')?['body/bucketId'], item().BucketID)"
                                },
                                "runAfter": {
                                    "Get_a_task": [
                                        "Succeeded"
                                    ]
                                },
                                "metadata": {
                                    "operationMetadataId": "83c63ed1-bb0f-46b9-a146-9cbe433e3ab0"
                                }
                            }
                        },
                        "runAfter": {
                            "List_my_tasks": [
                                "Succeeded"
                            ]
                        },
                        "metadata": {
                            "operationMetadataId": "b3708b9f-e926-402e-b59e-dd955c2af2b7"
                        }
                    }
                },
                "runAfter": {
                    "Scope_Create_Buckets_Name_List": [
                        "Succeeded"
                    ]
                },
                "metadata": {
                    "operationMetadataId": "57ae0ab0-df53-4192-a672-e998e878eb61"
                }
            }
        },
        "runAfter": {
            "Initialize_variable_Buckets": [
                "Succeeded"
            ]
        },
        "metadata": {
            "operationMetadataId": "5fb5226e-360f-4068-9d9a-9b90ff348419"
        }
    }
}

あとがき

Planner のコネクター要望にあげて、対応してもらうようなレベルだなぁとやってみて思いました。
そのうち更新されるんじゃないのかな?

keyword

how to get Bucket Name of Planner by Power Automate

3
3
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
3

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?