はじめに
SharePointは、Microsoftが提供する企業向けのファイル共有・情報共有サービスであり、特にMicrosoft 365やOffice 365の一部として利用されています。
SharePointの最も基本的な利用用途は、主には企業内でのファイル共有と情報共有となりますが、クラウドストレージサービスとして、社外となる関連会社や取引先ともファイルを簡単に共有できます。
今回はHULFT SquareとSharePointを連携させることによって業務の自動化につながる仕組みを構築していきます。
今回やること
HULFT Squareを利用して、SharePointに格納されているファイルをHULFT Square内のストレージへダウンロードします。
①スケジュールジョブを利用し、毎日18時に、SharePointから注文書ファイル(Excel形式)をダウンロードするスクリプトを実行
検証手順
Microsoft SharePoint連携用のコネクション作成
今回Microsoft SharePoint への認証はOAuth認証を使用します。
OAuth認証はID・パスワードベースとは異なるトークンベースの認証です。
認証のためにID・パスワードベースを毎回入力する必要がなく、またトークンには有効期限が設定されているためID・パスワードよりもセキュアな認証方法であると言えます。
1.SharePoint接続のコネクション設定
まず、HULFT SquareでSharePoint接続のコネクションを設定していきます。
[種類] に表示されるSharePoint接続
を選択いただき [次へ] ボタンをクリックします。
任意の [名前]、今回はSharePointe接続
と入力いただき、[次へ] ボタンをクリックします。
[ドメイン] にご契約のドメイン名と、[サイト名] にダウンロードしたいファイルが格納されているサイト名を設定し、[次へ] ボタンをクリックします。
サブサイトのファイルをダウンロードしたい場合は、[サイト名] に
site名/subsite名 という形で記載します。
[プロファイル] を選択し、[次へ] ボタンをクリックします。
以下をご確認いただき、[完了] ボタンをクリックします。これでSharePoint接続のコネクション設定は完了となります。
2.OAuth認証のコネクション設定(Entra ID側)
HULFT SquareからSharePointへOAuth認証で連携するためには、OAuth認証コネクション設定が必要になります。
OAuth認証のコネクション設定を行うにあたり、Entra ID(旧Azure AD)側に [アプリの登録] を行う必要があります。先に、アプリの登録を行います。
Azureのポータルサイトに接続し設定を実施していきます。
Azureポータル
Microsoft Entra IDの [ビュー] を選択します。
[アプリの登録] をクリックします。
[新規登録] をクリックします。
任意の [名前]、今回はHSQ_SharePoint
と入力いただき、
リダイレクトURLには、[プラットフォームの選択] では、Web
を選択し、https://app.square.hulft.com/connections/oauth2/callback
を入力し、[登録] をクリックします。
HULFT SquareへのリダイレクトURLは固定となります。このまま設定してください。
数秒後、アプリが作成されます。以下の画面で認証に必要な値を取得していきます。
① [概要] ページで表示される [アプリケーション (クライアント) ID] の値を取得します。
②、③ [エンドポイント] タブで [OAuth 2.0 承認エンドポイント (v2)] 、
[OAuth 2.0 トークン エンドポイント (v2)] の値を取得します。
④ [クライアントシークレット] の値を取得します。
[証明書とシークレット] ページで [新しいクライアントシークレット] をクリックします。
任意の [説明]、今回はHULFT SquareからSharePointへ接続
を入力して、[有効期限] を選択し、[追加] をクリックします。
必ず [値] を控えておいて下さい、一度しか表示されません。
次にAPIのアクセス許可設定を実施していきます。
[API アクセス許可] ページで [アクセス許可の追加] → [SharePoint] をクリックします。
以下の3つにチェックしてください。
AllSites.Manage
AllSites.Read
AllSites.Write
続けて、[API アクセス許可] ページで [アクセス許可の追加] → [Microsoft Graph] をクリックします。
[委任されたアクセス許可] をクリックします。
検索窓にoffline_access
と入力し、アクセス許可に表示される [offline_access] にチェックを入れ、[アクセス許可の追加] をクリックします。
管理者の同意を与えてください。
3.OAuth認証のコネクション設定(HULFT Square側)
続いてHULFT SquareでOAuth認証用のコネクションを設定していきます。
任意の [名前]、今回はOAuth 2.0認証_SharePoint
と入力いただき、[次へ] ボタンをクリックします。
[2.OAuth認証のコネクション設定(Entra ID側)] で取得した値を設定して、リフレッシュトークンを発行します
[スコープ] :Offline_access
とhttps:/ドメイン/.default
を設定します。
下記画面に遷移後、[承諾] ボタンをクリックすると、リフレッシュトークンが発行されます。
[適用] ボタンをクリックします。これでOAuth認証用のコネクション設定は終了です。
スクリプト作成
今回は「SharePoint連携」プロジェクト配下にSharePoint_ダウンロード
というスクリプトを作成します。
[HULFT Square Designer] を起動し、スクリプトを作成していきます。
[ツールパレット] より [クラウド>SharePoint>ドキュメントダウンロード] アイコンを選択しドラッグ&ドロップしてスクリプトキャンバスへ配置します。
[必須設定] タブを設定します。
[名前] 任意の名前、今回はドキュメント_ダウンロード
を入力
[コネクション] [1.SharePoint接続のコネクション設定] で作成したSharePoint接続
コネクションを選択
[認証コネクション] [2.OAuth認証のコネクション設定] で作成したOAuth 2.0認証_Sharepoint
コネクションを選択
[接続テスト] を実行して、接続に成功することを確認してください。
次に、[ライブラリ名を検索...] を実行して、ライブラリ名を取得します。
[ライブラリ名] はドキュメント
を選択し、
[ファイルパス] にSharePointのサイトの取得したいファイル名を指定し、
[ストレージファイルパス] にダウンロード先となるHULFT Squareのストレージのパスを指定したら、[完了] ボタンをクリックします。
下記のように [start] から [END] までドラッグ&ドロップでプロセスフローの矢印を繋ぐとファイルアンロード用スクリプトの完成です。
スケジュールジョブ設定
SharePointファイルのダウンロード用スクリプトを実行するスケジュールジョブを設定します。
以下のようにスケジュールジョブを登録します。
スケジュールジョブの設定は、HULFT Squareのチュートリアル「スクリプトの実行スケジュールを設定してみよう」をご参照ください。
検証結果確認
指定した18時にスケジュールジョブが起動され、該当のストレージにファイルが作成されていることが確認できました。
終わりに
いかがだったでしょうか。HULFT SquareとSharePointをつないで、よりデータを有効活用していただきたいと思います。
当記事が、業務改善の一助になれば幸いです。それではまた!