以下2つの記事の組み合わせでできます。
コード.gs
var CHANNEL_ACCESS_TOKEN = "TOKEN"; function doPost(e) { var contents = e.postData.contents; var obj = JSON.parse(contents); var events = obj["events"]; for(var i = 0; i < events.length; i++){ if(events[i].type == "message"){ reply_message(events[i]); } } } function reply_message(e) { var return_text; if(e.message.type=="text") { var input_text = e.message.text; return_text = LanguageApp.translate( input_text , "en" , "ja" ); } else { return_text = "文字を入力してね" } var postData = { "replyToken" : e.replyToken, "messages" : [ { "type" : "text", "text" : return_text } ] }; var options = { "method" : "post", "headers" : { "Content-Type" : "application/json", "Authorization" : "Bearer " + CHANNEL_ACCESS_TOKEN }, "payload" : JSON.stringify(postData) }; UrlFetchApp.fetch("https://api.line.me/v2/bot/message/reply", options); } |
意訳.gsアクセストークンを設定する この処理は以下を実行する 送信されたデータの内容を取得し そのJSONをオブジェクトに変換し eventsを取得する eventsの数だけ以下を繰り返す もしtypeがmessageなら reply_messageに渡す この処理は以下を実行する return_textという入れ物を作って もし受け取ったmessageのtypeがtextなら input_textに入れて 指定した言語で翻訳する messageのtypeがtextでなければ 設定したテキストを返す postDataに replyTokenを設定し messagesの typeを設定し textを設定する optionsに methodを設定し headersに Content-Typeを設定し Authorizationを設定し payloadにはpostDataをJSONに変換したものを設定する optionをつけてLINEのmessage reply APIをたたく |