前提・実現したいこと
GASでスプレッドシートの特定のセルが更新された時に、スラックに通知を送る関数を組みたいです。
具体的に説明すると、I列のステータスを更新した時に通知が送られるようにしたく思います。
発生している問題・エラーメッセージ
https://hooks.slack.com のリクエストに失敗しました(エラー: 400)。サーバー応答の一部: missing_text_or_fallback_or_attachments(応答の全文を見るには muteHttpExceptions オプションを使用してください)(行 28、ファイル「コード」)
該当のソースコード
var postText; /* ** GoogleSpreadSheetの変更をSlackに通知する関数 */ function postSheetChange(){ //自作の関数:slackに通知する文字列を作成 createSendMessage(); //slackに通知する文字列を設定 var postText = this.postText; //自作の関数: textをslackに通知する関数を呼び出す postSlack(postText) } /* ** textをslackに通知する */ function postSlack(text){ var url = "https://hooksxxxxxxxxxxxx" ; var options = { "method" : "POST", "headers": {"Content-type": "application/json"}, "payload" : JSON.stringify({ "channel" : "#チャンネル名", "text" : text, }) }; UrlFetchApp.fetch(url,options); } /* ** Slackに返す文字列を生成 */ function createSendMessage(){ var time = new Date(); var year = time.getFullYear(); var month = time.getMonth() + 1; var day = time.getDate(); var today = year + "/" + month + "/" + day + "/" var postText; var notifySheet = SpreadsheetApp.getActiveSpreadsheet(); //アクティブセルを取得する var myCell = notifySheet.getActiveCell(); //アクティブセルがI列の場合(仕事の進捗)のみ通知する if(myCell.getColumn() == 9){ var rowNum = myCell.getRow(); this.postText = "(" + today + ")新規制作依頼スレ\n" + "案件名:" + notifySheet.getRange("B" + rowNum).getValue() + "\n" + "依頼者:" + notifySheet.getRange("C" + rowNum).getValue() + "\n" + "静止画本数:" + notifySheet.getRange("E" + rowNum).getValue() + "\n" + "動画本数:" + notifySheet.getRange("G" + rowNum).getValue() + "\n" + "ステータス:" + notifySheet.getRange("I" + rowNum).getValue() + "\n" + "BOX URL:" + notifySheet.getRange("H" + rowNum).getValue() + "\n" + "SS URL" + "https xxxxxxxxxxxx"; } }
試したこと
ネットを探して色々試してみましたが、エラーメッセージの意味が理解できずでして。。。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/12/11 02:50