☆PSGSuiteでPowerShellからG Suite APIを触っちゃお☆


☆PSGSuiteとは☆

Powershell module for Google / G Suite API calls wrapped in handy functions.

https://github.com/SCRT-HQ/PSGSuite より引用)

☆何ができる☆

例えば……こんなスクリプトをPowerShellで実行してみるよ☆

New-GSCalendarEvent "☆ミーティング☆" -LocalStartDateTime (Get-Date "21:00:00") -LocalEndDateTime (Get-Date "22:00:00")

そしたらGoogle カレンダーを見てみるよ(。`・∀・´)

すると……

今日の21:00-22:00に ☆ミーティング☆ 入ってるじゃない!!!!!!
びっくり~(*゜0゜)

☆セットアップ☆

この章の内容は基本的にドキュメントに書いてあるものを色々はしょって和訳したものだよ~
(原文: https://psgsuite.io/Initial%20Setup/
必要最低限の内容をなるべく簡単に書いたつもりだけど、もしうまくいかないところがあったら、原文に詳しく書いてあるかも~(・ρ・*)

☆必要なもの☆

  • PowerShell 4.0以上 あるいは PowerShell Core 6.0以上
  • G Suite アカウント(全機能を使うには管理者アカウントが必要だよ)
    • (でも普通のアカウントでもけっこう色々できるので、今回は普通のアカウントを対象にするよ~)

☆インストール☆

☆PowerShellGetのアップデート☆

PowerShell Galleryから取ってくるのが一番簡単だから、その方法を紹介するよ(。`・∀・´)
ただ、この方法はPowerShellGetコマンドレットが最新版じゃないといけなくて、しかも初めてこのコマンドを使う人は、ほとんどの場合バージョンが1.0.0.1で止まってます(*゜0゜)
Windows 10 かつ PowerShell 5.0以上なら簡単で
https://blog.shibata.tech/entry/2017/12/18/004105
に書いてあるとおりにすれば大丈夫です

というのも

Install-Module PowerShellGet -Scope CurrentUser -Force -AllowClobber

これでおしまいです!ヾ(@>▽<@)ノ

☆PSGSuiteのインストール☆

一瞬です(*゜0゜)

Install-Module -Name PSGSuite -Scope CurrentUser

おわり(*゜0゜)

☆認証情報の設定☆

PSGSuiteでは管理者アカウントじゃなくても以下のAPIが使えるよ☆

  • Contacts API
  • Gmail API
  • Google Calendar API
  • Google Docs API
  • Google Drive API
  • Google Sheets API
  • Google Slides API
  • People API (new Contacts API)
  • Tasks API

このAPIを使うために、ここから認証情報の設定をしていきますよ~∈(´__________`)∋1

☆プロジェクト作成☆

ここをクリックすると、こんな感じの画面に飛びます!

「続行」と書かれた青いボタンを押してね~(。`・∀・´)
(ドロップダウンメニューはそのままで大丈夫だよ~ん)

☆同意画面の設定☆

次の画面はたぶんこんな感じ~

これは認証情報のセットアップお助けウィザード君なんですけど、スキップしちゃいます(*゜0゜)
画面上部、青文字の「クライアントID」をクリックです!(。`・∀・´)

次の画面はこんな感じ

「同意画面を設定」と書かれた青いボタンを押しますよ~

次のUser Typeを選ぶ画面ですが、組織に属していない個人アカウントに「内部」は選べないので、必然的に「外部」を選ぶことになります

選択したら青の「作成」ボタン!

次は同意画面の内容を決めます
設定すべきところは二か所あって

  1. アプリケーション名を「PSGSuite」に設定

  2. 少し下にある「スコープを追加」ボタンを押すと……

    ポップアップが出てくるので、左上のチェックボックスをチェックして、右下の「追加」を押します!

    ポップアップが閉じたら一番の「保存」ボタンをクリックします
    これで同意画面の設定はおわりです!☆

☆クライアントIDの取得☆

まず、左のメニューから「認証情報」タブを選びます(。`・∀・´)

画面上部の「+ 認証情報を作成」をクリックするとドロップダウンが開くので、そこから「OAuth クライアント ID」をクリックします!

次の画面でアプリケーションの種類を聞かれます

「デスクトップアプリ」が適切です!

選択すると、クライアントの名前を何にするか聞かれます

例えば「PSGSuite」としておくと、後々わかりやすいと思います!

「作成」ボタンを押すとクライアントIDの出来上がり☆
クライアントIDとクライアントシークレットがポップアップされたはずです

ポップアップを閉じて認証情報タブに戻ります

さっき決めた名前でクライアントが登録されているのが見えますか?(・ρ・*)
その右端にある矢印アイコンをクリックすると、クライアントIDやクライアントシークレットが含まれたJSONがダウンロードされます!
好きなフォルダに移して大丈夫ですが、次のステップで必要なのでパスを控えておいてください

これでGoogle Developer Console側の設定はおわりです!ヾ(@>▽<@)ノ

☆PSGSuite Configuration Fileの作成☆

まずPowerShellにコマンドをimportします(。`・∀・´)

Import-Module PSGSuite

そして、PSGSuiteと、さっきのJSONを紐づけてあげます

$ConfigName = "MyConfig"
$ClientSecretsPath = "C:\Keys\client_secret.json"
$AdminEmail = "[email protected]"
Set-PSGSuiteConfig -ConfigName $ConfigName -SetAsDefaultConfig -ClientSecretsPath $ClientSecretsPath -AdminEmail $AdminEmail
  • $ConfigNameに適当な名前
  • $ClientSecretsPathにJSONのパス
  • $AdminEmailにメールアドレス

を入れて実行すれば完了です!

☆初回認証☆

最後に、ブラウザーで認証を済ませます
任意のコマンドを実行すると認証プロセスに入ります!(。`・∀・´)

Get-GSGmailProfile -Verbose

Windows PowerShellを使っている場合

  • 自動でブラウザが立ち上がるよ
  • 認証を済ませると先ほど打ったコマンドが実行されて完了だよ☆

PowerShell Coreを使っている場合

  • リンクが表示されるので手動で踏みます
  • 認証を済ませると認証コードが発行されるので、ターミナルにコピペしてね
  • Enterを押すと先ほど打ったコマンドが実行されて完了だよ☆

参考までに、PowerShell 7 での実行結果のスクショを置いておきます∈(´__________`)∋

☆参考☆


  1. 原文が書かれたときからいくらか時間が経っているのか、Google Developer Console君のUIが、軽微ながら現在と違っていました。やや不便に思ったので、ここからの解説は執筆時点でのUIをもとに、スクショ多めで冗長性を持たせてあります(。`・∀・´)