複数のメンバーのカレンダーの内容を。毎日Slackでまとめてみられるように通知したいです。
https://bzbot.work/2019/04/10/googlecalendar-slack/
こちらを参考にしたのですが、エラーは出ませんがSlackに通知が来ません…。
初心者なもので、どこがおかしいのか見当もつきません。
ご教示お願い致します!
var date = new Date(); //アクティブなシートを取得 var sheet = SpreadsheetApp.getActiveSpreadsheet(); //「calendar_ID」のシートをアクティブにして、シート情報をcalendarIdに取得 var calendarId = sheet.getSheetByName('Calendar_ID'); Logger.log(calendarId.getName()); //カレンダーにセットされているGoogleCalendarのIDを取得する function getId(){ //calendarIDが入っている最終行を取得(固定) var lastR1 = calendarId.getLastRow(); Logger.log("【lastR】:" + lastR1); //セットされているIDのリストを順番に取得してgetCalに引数として渡す for (var i = 1; i < lastR1 ; i++){ //カレンダーIDを指定して、カレンダーを取得 var calId = calendarId.getRange('A'+(i+1)).getValue(); Logger.log('【calId】' + calId); //IDを渡してカレンダーから情報を取得 var msg = getCal(calId); //取得したカレンダーの情報をSlackにPOSTする sendToSlack(msg); } } function getCal(id) { Logger.log('【id】' + id); var message = ''; var calendar = CalendarApp.getCalendarById(id); //getEventsForDayは引数の日付の予定を全て取得する var events = calendar.getEventsForDay(date); //eventsに入っている要素の数だけ実行 for (var i = 0; i < events.length; i++) { Logger.log('events要素' + i + '目'); var title = events[i].getTitle(); var startTime = events[i].getStartTime(); var endTime = events[i].getEndTime(); var duration = (endTime - startTime) /(1000*60)/(60); var start = Utilities.formatDate(startTime,"JST","MM/dd hh:mm"); //1回目はアドレスをTOPに表示したいため(Slackで表示を加工するため細々記載している) if (i === 0){ message += id + '```' + '\n' + (i + 1).toString() + '.' + '[' + start + ' (' + duration + ')' + ']--' + title + '\n'; }else{ message += (i + 1).toString() + '.' + '[' + start + ' (' + duration + ')' + ']--' + title + '\n'; } } Logger.log('message:' + message); //Slackで送る形式を指定したいため '```' を最後に追加 return message + '```'; } function sendToSlack(postMsg) { Logger.log('postMsg:' + postMsg); //Slackのチャンネル名を指定 var ch = "#test_slackmf"; //SlackのwebhookURLを指定 var url = "https://hooks.slack.com/services/●●●"; //渡すデータを指定する var data = { "channel" : ch, "username" : "Googlecalendar-Bot", "text" : postMsg, "icon_emoji" : ":spiral_calendar_pad: " }; var payload = JSON.stringify(data); var options = { "method" : "POST", "contentType" : "application/json", "payload" : payload }; var response = UrlFetchApp.fetch PropertiesService.getScriptProperties().getProperties().url,options} コード
あなたの回答
tips
プレビュー