Google Apps Script(GAS)で、スプレッドシートからTwitter API v2経由でツイッターに自動投稿するTwitter botの作成方法を備忘録として記載。本記事では準備編としてTwitter Developerアカウント登録してTwitter認証設定までを行う。
実際のTwitter Bot作成とコードに関しては、下記に記載。
テキスト投稿のみ
テキスト+画像投稿
Twitter 設定
Twitter developerアカウント登録
TwitterのDeveloper Platformにアクセスし、ナビゲーション右にある「Developer Portal」をクリック。
https://developer.twitter.com/en
data:image/s3,"s3://crabby-images/8706a/8706a6317b53d828857ea0eea678bbbbd57754ab" alt=""
自動的にProアカウント作成を勧められるが、今回はフリーアカウントを作成したいので、ボタンの下にある『Sign up Free Account』をクリック
https://developer.twitter.com/en/portal/petition/essential/basic-info
data:image/s3,"s3://crabby-images/9d28d/9d28de8e1999bed99172e4e209929299a646b01b" alt=""
下記の画面に移動し、Twitter dataとAPIの利用目的の記入を促される。
250文字以上入力する必要があるが、審査ないので内容は何でもOK。
https://developer.twitter.com/en/portal/petition/essential/terms?plan=free
data:image/s3,"s3://crabby-images/dc98d/dc98dda6af86985007adf1e96f09d9b5b7c8aa4e" alt=""
私の場合は、ChatGptに下記のように質問したら、即座に利用目的を英語で出力してくれたので、これをコピペ
data:image/s3,"s3://crabby-images/0387c/0387cf08818d836d517d5211d7954e82f4c727b8" alt=""
data:image/s3,"s3://crabby-images/e543f/e543f55ac9d4ce1282784e320e9991636e310b34" alt=""
I intend to use the Twitter API to develop a Twitter bot that automates the process of posting tweets. The bot will source its content from a Google Spreadsheet, where each row contains the text for a tweet. The spreadsheet will be managed by a team that curates the content, ensuring it adheres to Twitter’s guidelines and policies.
Submitボタンを押すと、管理画面にすぐにリダイレクトされる。承認待ちで数時間・数日かかるとかはない。
data:image/s3,"s3://crabby-images/23d2a/23d2aa1e247d5b531c32fa1fc752cd7a16d5d128" alt=""
Client ID・Client Secret取得
左サイドバーの赤枠の部分(画像では名前を変えているが、デフォルトではDefault project-XXXの下にある、TwitterIDから始まっている)をクリック。
上部のタブのうち、「Keys and tokens」をクリックし、下にスクロールすると、「OAuth 2.0 Client ID and Client Secret」という項目がある。
Client IDは記載されているのでコピーしてメモ。Client SecretはRegenerateボタンを押して表示された値をコピーしてメモしておく。あとで、GASのスクリプトに記載する。
data:image/s3,"s3://crabby-images/a8b89/a8b8935a6f63de9b1d14505bb2e81aa03a07fe2e" alt=""
User authentication設定
同じ画面の上部の「Settings」タブをクリックし、「User authentication settings」項目のEditボタンをクリック。
data:image/s3,"s3://crabby-images/91de6/91de65aba1f5ba95909beea385d08b3f4e07d98b" alt=""
App permissions:Read and write
Type of App:Web App, Automated App or Bot
を選択
data:image/s3,"s3://crabby-images/77a76/77a76e3bfef4260f58f0c0fd01e357678e5fe424" alt=""
App info
「Callback URI / Redirect URL (required) 」にGASのコールバックURLを設定する。
GASのコールバックURL:https://script.google.com/macros/d/GASのスクリプトID/usercallback
GASのスクリプトIDの部分は、GASを作成する時に表示されるので、GASの作成にうつる。
data:image/s3,"s3://crabby-images/b0c20/b0c20cb58900ca19a3b1606f4480cf0efbd549c5" alt=""
Google App Scriptでtwitter認証を作成
Twitterボット作成の元となるスプレッドシートを新規作成する。
拡張機能タブから「Apps Script」を選択し、GASプロジェクトを表示する。
data:image/s3,"s3://crabby-images/1d5e9/1d5e9d03eb80e084874a5170c4f0884a7ab95855" alt=""
表示されるGASコード作成画面のURLのうち、projects/と/editの間に表示されている固有の値が、GASのスクリプトIDになるので、コピーする。
先ほどのTwitterのUser authentication設定のApp infoのCallback URI設定の画面に、スクリプトIDを添えてコールバックURLを設定する。
data:image/s3,"s3://crabby-images/94bbf/94bbf024df53e2d88bae3b764b9952202b4d15db" alt=""
https://script.google.com/macros/d/GASのスクリプトID/usercallback
OAuth2ライブラリ追加
GASコード作成画面の左サイドバーの「ライブラリ」をクリックする。ライブラリの追加という画面が開くので、スクリプトIDの欄に、下記のスクリプトIDを入力して検索。
OAuth2のスクリプトID1B7FSrk5Zi6L1rSxxTDgDEUsPzlukDsi4KGuTMorsTQHhGBzBkMun4iDF
data:image/s3,"s3://crabby-images/57526/57526536c64aebedc9240127d55d4e835fb724f2" alt=""
すると、IDの欄にOauth2と記載された検索結果が表示されるので、追加ボタンをクリックして、Oauth2ライブラリを追加する。
data:image/s3,"s3://crabby-images/5f85f/5f85f2a5f1b636dc8a3d0e5600502ea16e9073cf" alt=""
Twitter API認証処理のGASコード作成
下記のTwitter API認証処理のGASコードをコピペ。
CLIENT_IDとCLIENT_SECRETは、Twitter APIの「OAuth 2.0 Client ID and Client Secret」の項目で取得してメモした「Client ID」と「Client Secret」を記載する。
const CLIENT_ID = 'XXX'
const CLIENT_SECRET = 'XXX'
function getService() {
pkceChallengeVerifier();
const userProps = PropertiesService.getUserProperties();
const scriptProps = PropertiesService.getScriptProperties();
return OAuth2.createService('twitter')
.setAuthorizationBaseUrl('https://twitter.com/i/oauth2/authorize')
.setTokenUrl('https://api.twitter.com/2/oauth2/token?code_verifier=' + userProps.getProperty("code_verifier"))
.setClientId(CLIENT_ID)
.setClientSecret(CLIENT_SECRET)
.setCallbackFunction('authCallback')
.setPropertyStore(userProps)
.setScope('users.read tweet.read tweet.write offline.access')
.setParam('response_type', 'code')
.setParam('code_challenge_method', 'S256')
.setParam('code_challenge', userProps.getProperty("code_challenge"))
.setTokenHeaders({
'Authorization': 'Basic ' + Utilities.base64Encode(CLIENT_ID + ':' + CLIENT_SECRET),
'Content-Type': 'application/x-www-form-urlencoded'
})
}
function authCallback(request) {
const service = getService();
const authorized = service.handleCallback(request);
if (authorized) {
return HtmlService.createHtmlOutput('Success!');
} else {
return HtmlService.createHtmlOutput('Denied.');
}
}
function pkceChallengeVerifier() {
var userProps = PropertiesService.getUserProperties();
if (!userProps.getProperty("code_verifier")) {
var verifier = "";
var possible = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._~";
for (var i = 0; i < 128; i++) {
verifier += possible.charAt(Math.floor(Math.random() * possible.length));
}
var sha256Hash = Utilities.computeDigest(Utilities.DigestAlgorithm.SHA_256, verifier)
var challenge = Utilities.base64Encode(sha256Hash)
.replace(/\+/g, '-')
.replace(/\//g, '_')
.replace(/=+$/, '')
userProps.setProperty("code_verifier", verifier)
userProps.setProperty("code_challenge", challenge)
}
}
function logRedirectUri() {
var service = getService();
Logger.log(service.getRedirectUri());
}
function main() {
const service = getService();
if (service.hasAccess()) {
Logger.log("Already authorized");
} else {
const authorizationUrl = service.getAuthorizationUrl();
Logger.log('Open the following URL and re-run the script: %s', authorizationUrl);
}
}
Twitter API認証テスト
Twitter APIで初回実行する際には、認証が必要。
実行する関数のプルダウンでmainを選択し(コピペした段階ではデフォルトでgetService関数になっているのでmain関数に変更しないと認証テストが実行されない)、「実行」ボタンをクリック。
data:image/s3,"s3://crabby-images/50aa6/50aa6add4581904352bf6cd8eb847ab117cbeecf" alt=""
data:image/s3,"s3://crabby-images/7fbe8/7fbe8b0040d1c112471689e83a03fa3eefa09ad3" alt=""
「承認が必要です」というポップアップが表示されるので、「権限を確認」をクリック
data:image/s3,"s3://crabby-images/1cf0b/1cf0b38b19b47248ae8f837be64a7cf2d7b90411" alt=""
さらにポップアップが開くので、「許可」をクリック
data:image/s3,"s3://crabby-images/facce/facceb934607924cd159e9474cea66c8a531e7d5" alt=""
すると、GASスクリプトの実行ログの欄に、下記ログが表示される。
「Open the following URL and re-run the script:URL」というログになっており、URL部分をコピーして、ブラウザの新規タブにペーストして開く必要がある。
data:image/s3,"s3://crabby-images/530b7/530b78ddf55df0a2259cedd01763513947c8e2ff" alt=""
こんな感じでコピーして、新規タブに貼り付けて開く
data:image/s3,"s3://crabby-images/5c2b5/5c2b527d886c53b8bdcc504af25d12ec460e86a8" alt=""
すると、twitter apiの認証画面が開くので「Authorize app」ボタンをクリックして認証する。
data:image/s3,"s3://crabby-images/93fdf/93fdf22fd6543d27da10f5df9f6eee606c4e2894" alt=""
すると、ブラウザで「Success!」と表示されるので、これでTwitter API認証の完成!
data:image/s3,"s3://crabby-images/2699d/2699d3fb129fa20e26f9f4d1cf0299c7a495c6c8" alt=""
これで、スプレッドシートからTwitter botを投稿する準備完了である。
次は、いよいよ、twitter bot投稿の中身をスプレッドシートとGASで作成していく。
それでは♪
コメント
最後のところで
問題が発生しました
アプリにアクセスを許可できません。前に戻ってもう一度ログインしてください。
と出てしまいます。
コメントありがとうございます。
書き記事を参考に、「詳細」をクリックし、「無題のプロジェクト(安全ではないページ)に移動」をクリックして、許可いただければと思います。
https://best-cloud.jp/google-apps-script-authentication/
twitter apiの認証画面が開くので「Authorize app」ボタンをクリックして認証する。
トークンが無効か、有効期限が切れています。もう一度お試しください。と表示されてしまいます
コメントありがとうございます。
Access TokenとAccess Token Secretが有効期限切れになっていることが原因だと思いますので、Twitter Developer Portalにログイン→プロジェクトとアプリを選択→「Keys and tokens」タブを開いて、Access TokenとAccess Token Secretの箇所でRegenerateボタンをクリックして新しいトークンを生成してみてください。