質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

Twitter

Twitterは、140文字以内の「ツイート」と呼ばれる短文を投稿できるサービスです。Twitter上のほぼ全ての機能に対応するAPIが存在し、その関連サービスが多く公開されています。

Q&A

0回答

536閲覧

GASでエラー。authCallbackができません。

Hasemi

総合スコア0

Google Apps Script

Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

Twitter

Twitterは、140文字以内の「ツイート」と呼ばれる短文を投稿できるサービスです。Twitter上のほぼ全ての機能に対応するAPIが存在し、その関連サービスが多く公開されています。

0グッド

0クリップ

投稿2022/06/19 01:34

GASでTwitter上の特定のキーワードを含むツイートをRTするボットを作成したいのですが、authCallbckのfunctionを実行すると、以下のエラーメッセージが出てきてしまい、原因がわからず困っています。

イメージ説明

コード全体

// 認証用URL取得 function getOAuthURL() { Logger.log(getService().authorize()); } // サービス取得 function getService() { return OAuth1.createService('Twitter') .setAccessTokenUrl('https://api.twitter.com/oauth/access_token') .setRequestTokenUrl('https://api.twitter.com/oauth/request_token') .setAuthorizationUrl('https://api.twitter.com/oauth/authorize') // 設定した認証情報をセット .setConsumerKey(PropertiesService.getScriptProperties().getProperty("CONSUMER_API_KEY")) .setConsumerSecret(PropertiesService.getScriptProperties().getProperty("CONSUMER_API_SECRET")) .setCallbackFunction('authCallback') // 認証情報をプロパティストアにセット(これにより認証解除するまで再認証が不要になる) .setPropertyStore(PropertiesService.getUserProperties()); } // 認証成功時に呼び出される処理を定義 function authCallback(request) { var service = getService(); var authorized = service.handleCallback(request); if (authorized) { return HtmlService.createHtmlOutput('success!!'); } else { return HtmlService.createHtmlOutput('failed'); } } // メイン関数 function main() { // 実行時間測定開始 var start = new Date(); // ホームタイムライン取得 var timeLine = getTimeLine(); console.log("更新ツイート数: " + timeLine.length ) // 検索条件に合致するTweetのid一覧を取得 var idArray = getTweetId(timeLine) console.log("Retweet数: " + idArray.length )  // id一覧に基づきRetweet postRetweet(idArray); // 実行時間の記録 var end = new Date(); var time_past = (end - start) / 1000; console.log("実行時間: " + time_past + "s") } // ホームタイムライン取得(前回取得時からの更新分) function getTimeLine() { // 前回取得時の最新Tweet id var spread = SpreadsheetApp.getActiveSpreadsheet(); var sheets = spread.getSheets(); var since_id = sheets[0].getRange(1,1).getValue(); // ホームタイムライン取得(前回取得時からの更新分) var service = twitter.getService(); var response = service.fetch("https://api.twitter.com/1.1/statuses/home_timeline.json?count=200&include_entities=false&since_id=" + since_id , { method: "get" }); var timeLine = JSON.parse(response); // 取得したツイートが200を越えた場合はエラー if (timeLine.length > 200){ console.error("全てのツイートを網羅できていません") } // タイムラインに更新があった場合、最新Tweet idの記録 if (timeLine[0]) { sheets[0].getRange(1,1).setValue(timeLine[0].id_str); } return timeLine; } // タイムラインの中から抽出したい条件に一致するTweet idを取得 function getTweetId(timeLine){ var idArray = []; // Tweetごとに条件に一致するかを判定 timeLine.forEach(function(value) { var text = value.text; // 条件①"XXX"という文字列を含む if (text.match(/XXX/) != null) { } }); return idArray; } // id一覧に基づきRetweet function postRetweet(idArray){ // Retweet var service = twitter.getService(); idArray.forEach(function(value) { var url = "https://api.twitter.com/1.1/statuses/retweet/" + value + ".json"; var response = service.fetch("https://api.twitter.com/1.1/statuses/retweet/" + value + ".json", { method: "post", payload: { trim_user: true } }); }); }

参考にしたURLはこちらです。
https://tech-cci.io/archives/4228
https://note.com/macaronloving/n/n267402b58fe4

初心者のため、初歩的なところから教えて頂けますと幸いです。よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問