概要
ワークショップの参加申込の受け付け、発表要旨ファイルの事前受け取りのためにPowerAutomateの練習も兼ねて作りました。
発表要旨ファイルはSharePointの「ファイルの要求」で受け取ります。Formsに入力された申込者のメールアドレスの確認を兼ねたメールの本文にSharePointのURLを記載します。メールの送信はGmailで行います。Formsで受け付けた情報はExcel Onlineに追記していきます。Formsの受付をトリガーとしてここまでをPowerAutomateで行います。
Microsoft 365 Business Standardを使える環境で作りましたが、Microsoft 365 Business BasicでもPowerAutomate、SharePoint、Formsが使えるようなので問題ないのだと思います。
「ファイルの要求」はMicrosoftの公式ページではこの「SharePoint または OneDrive でファイル要求を有効にする」に次のように記載されており、今回の用途に適していそうです。
OneDrive または SharePoint の ファイル要求機能 を使用すると、送信するリンクを使用して他のユーザーがファイルをアップロードできるフォルダーを選択できます。 ファイルを要求するPeopleは、ファイルのみをアップロードできます。フォルダーの内容を表示したり、ファイルを編集、削除、またはダウンロードしたり、他のユーザーがファイルをアップロードしたかを確認することもできません。
流れ
PowerAutomateのフロー
- Formsで受け付け
- Excelに受け付け内容を追記
- Formsで受け付けた宛先に、受付番号、ファイルアップロード用URLを記載したメールをGmailで送信
準備
次の3つを準備してからPowerAutomateを作ります。
- Forms作製
- SharePointのフォルダ作成、設定、URL取得
- Excelのテーブル作製
Forms
- 新しいフォーム
- フォームの名前を記載し、メールアドレスと名前の記載欄を「必須」で追加
- 設定で、「すべてのユーザーが回答可能」「回答を受け付ける」「お礼のメッセージをカスタマイズ」「送信後に応答の受信を許可する」
- 「回答を収集」でリンクをコピー
「回答を収集」のリンクの「id=」以下をPowerAutomateでのForms指定に使用することにな
SharePoint
チームサイトの作成
ファイルアップロード用フォルダー作成
設定
SharePointで「ファイルの要求」を行えるようにします。デフォルトではこれが行えないようなので、管理者権限で設定を変更しました。
Microsoftの公式ページではこの「SharePoint または OneDrive でファイル要求を有効にする」に記載されています。SharePoint Online 管理シェルを使うことになり、使い始めるまでの手順は「SharePoint Online 管理シェルの使用を開始する」に記載されています。
これらに従い次の手順を実行しました。
- SharePoint Online 管理シェルをインストール
- 「SharePoint Online 管理シェルの使用を開始する」の「多要素認証 (MFA) を使用して接続するには」に従って接続(多要素認証でない場合は「ユーザー名とパスワードを使用して接続する場合」のようだが未確認)
- RequestFilesLinkEnabled を確認する箇所は次のコマンドを実行して確認
Get-SPOSite -Identity <SiteURL> | Select RequestFilesLinkEnabled
通常は、Falseになっている。
4. 「ファイルの要求」を有効にするために次のコマンドを実行
Set-SPOSite -Identity <SiteURL> -RequestFIlesLinkEnabled $True
なお、「ファイルの要求」を無効にするのは次のコマンド。ファイルを集め終わった際には無効にしておくのが良さそう。
Set-SPOSite -Identity <SiteURL> -RequestFIlesLinkEnabled $False
ただ、ここまでしなくても「ファイルの要求」リンクの削除だけでも良いであろう。
「ファイルの要求」URL取得
- 作成したチームサイトに移動
- ドキュメント
- ファイルアップロード用フォルダーを選択
- 「ファイルを要求する」を実行
- アップロード画面への表示文を記載し、「次へ」
- リンクをコピーして控えておき、「完了」
控えたリンクを開くことでチームサイトのURLはわかってしまいますが、「ファイルを要求する」を有効にしたからといってチームサイトにアクセスできないのは確かそうでした。
「ファイルの要求」リンクの削除
ファイルを集め終わった際に行っておく。
Excel Online
- 新しい空白のブックを作成
- テーブルの見出しとする「受付番号」「E-mail address」「Name」を記載
- これら3つのセルを選択し、「挿入」の「テーブル」でテーブルの作成
- 「先頭行をテーブルの見出しとして使用する」にして「OK」
PowerAutomateで使用するテーブル名は「テーブルデザイン」から確認できる。デフォルトは「テーブル1」になるようだ。
PowerAutomate
- 作成
- 自動化したクラウド フロー
- フォームIDに「カスタム値の入力」でフォーム作成での「回答を収集」のリンクの「id=」以下を記載
- 新しいステップで、Formsを検索し「応答の詳細を取得する」
- フォームIDは先ほどと同じ。応答IDは「応答ID」を選択
- 新しいステップで、Excelを検索し「表に行を追加」
- 場所、ドキュメントライブラリ、ファイルで先ほど作成したExcel Onlineのファイルを選択
- テーブルはプルダウンから先ほど選択した「テーブル1」を選択
- テーブルに設定した見出しが表示されるので、それぞれにフォームの対応する項目を選択
- 新しいステップで、Gmailを検索し「メールの送信」(Gmailの認可が必要)
- 宛先の右下の「動的コンテンツの追加」をクリック
- 宛先に「応答の詳細を取得する」の「E-mail address」を選択
- メールの件名、本文(ボディ)を記載。本文にはSharePointの「ファイルの要求」URL取得で控えたURLを記載
- フローの保存
注意点
Botよけ、SharePointへのファイルアップロードの制限が必要と思いますが、そこまではできていません。いたずらで大量にファイルを送りつけられたりすることに対する対策はどうすれば良いのだろう。別途、SharePointにファイルがアップロードされるたびに、ファイルサイズ、頻度を確認して閾値を超えたら一時停止とかあるのかな。