LoginSignup
1
0

Kintone × Google Apps Scritでメール通知実装機能を実装する方法

Last updated at Posted at 2023-08-30

はじめに

Kintoneの標準機能では、レコード追加、編集後にメールを送る機能は1アカウントごとに設定が必要です。 1アカウントを使いまわしている企業にとっては不便な仕様となっています。 この問題を解決するために、KintoneとGoogle Apps Scriptをwebhookで連携し、任意のユーザーに対してメール通知を送る機能を実装します。
Webhook は、2 つのアプリケーション・プログラミング・インタフェース (API) 間の軽量なイベント駆動型の通信を可能にする HTTP ベースのコールバック機能であり、Webhook はさまざまな Web アプリケーションで他のアプリケーションから少量のデータを受信するのに使用され、また GitOps 環境での自動化ワークフローのトリガーにも使用されます。

Google Apps Script側での設定方法

  1. Googleアカウントにログインする
  2. Googleドライブを開く
  3. Chromeの場合、アプリメニューからドライブをクリックするとドライブが開きます。

    image.png

  4. スクリプトファイルの作成
  5. ドライブにログイン後、スクリプトファイルを作成したい場所で右クリック→その他→Google Apps Scriptを選択してください。

    image.png

  6. コーディング
  7. Kintone.js
    function doPost(e) {
    
      /********************/
      /* 問い合わせ情報の取得 */
      /********************/
      const parsedJson = JSON.parse(e.postData.getDataAsString());
      const support_Days = parsedJson.record.対応年月日.value; 
      const support_Time = parsedJson.record.対応日時.value;
      const supporter = parsedJson.record.対応者.value; 
      const incident = parsedJson.record.障害内容.value; 
      const result = parsedJson.record.結果.value; 
    
      /*************/
      /* 通知先情報 */
      /*************/
      const subject = "ここに件名を記載する";
      const email_to = "ここに宛先メールアドレスを記載する";
      const email_from = "ここに送信者メールアドレスを記載する(GmailアカウントでOK)";
    
      /**************/
      /* メッセージ本文 */
      /**************/
      let message_body = "対応を行いました。\n";
          message_body += '■対応年月日\n';
          message_body += support_Days+'\n';
          message_body += '■対応日時\n';
          message_body += support_Time+'\n';
          message_body += '■対応者\n';
          message_body += supporter +'\n';
          message_body += '■障害内容\n';
          message_body += incident +'\n';
          message_body += '■結果\n';
          message_body += result +'\n';
    
      /**************/
      /* メッセージ送信 */
      /**************/
      GmailApp.sendEmail(
        email_to,
        subject,
        message_body,
        {
          from: email_from, 
          name: "送信者の名前"
        }
      ); 
    }
    

スクリプトの説明

Kintoneアプリのレコード情報の取得 parsedJson.record.○○.value
〇〇を使用するアプリの各名称を記入してください。
  const parsedJson = JSON.parse(e.postData.getDataAsString());
  const support_Days = parsedJson.record.対応年月日.value; 
  const support_Time = parsedJson.record.対応日時.value;
  const supporter = parsedJson.record.対応者.value; 
  const incident = parsedJson.record.障害内容.value; 
  const result = parsedJson.record.結果.value; 

メール送信
””の中に各項目の記載をしてください。
email_toはスクリプト作成しているGmailアドレスを記載してください。

  const subject = "ここに件名を記載する";
  const email_to = "ここに宛先メールアドレスを記載する";
  const email_from = "ここに送信者メールアドレスを記載する(GmailアカウントでOK)";

送信者の名前
ここに受信者へ表示させたい送信者の名前を記載してください。

name: "送信者の名前"

スクリプトの公開設定

  1. デプロイをする
  2. デプロイ→新しいデプロイをクリックする

    image.png

  3. 公開設定
  4. 種類の選択:ウェブアプリ アクセスできるユーザー:全員

    image.png

Kintone側での設定方法

  1. webhookを有効にする
  2. アプリ内設定から設定タブのwebhookをクリックしてください。
  3. 追加するをクリック
  4. Webhook URLを貼り付け、通知を送信する条件を選択する
  5. Webhook URLは、GAS上でデプロイ完了後に表示されます。 また、デプロイの管理から確認することもできます。 https://を除いたURLを貼り付けてください。
1
0
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
1
0