No release in over a year
Ruby implementation for Twitter client, using V2 API and OAuth 2.0.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

 Project Readme

twitter_tweet_bot

Tweet Bot with Twitter's V2 API.
(by OAuth 2.0 with PCKE)

Getting Started

# Gemfile
gem 'twitter_tweet_bot'

Then run bundle install.

Usage

require 'twitter_tweet_bot'

TwitterTweetBot.post_tweet(<ACEESS_TOKEN>, 'Yeah!')
  1. Configuration
  2. Issue Authorization URL
  3. Go to Authorization URL
  4. Fetch Access Token
  5. Post Tweet
Details

Step1. Configuration

require 'twitter_tweet_bot'

TwitterTweetBot.configure do |config|
  # Twitter's Bot Name (any)
  config.name = 'iambot'
  # Twitter's Client ID
  config.client_id = '*****'
  # Twitter's Client Secret
  config.client_secret = '*****'
  # Redirect URL After Authorization
  config.redirect_uri = 'https://example.com/twitter/callback'
  # Twitter's App Scopes with OAuth 2.0
  config.scopes = %w[tweet.read tweet.write users.read offline.access]
end

Step2. Issue an authorization url

authorization = TwitterTweetBot.authorize
# =>
#  #<TwitterTweetBot::Entity::Authorization
#   @code_verifier="*****",
#   @state="***",
#   @url="https://twitter.com/i/oauth2/authorize?response_type=code&redirect_uri=<YOUR_REDIRECT_URI>&client_id=<YOUR_CLIENT_ID>&scope=<SCOPES>&code_challenge=*****&code_challenge_method=S256&state=***">

Step3. Redirect (or Go) to authorization.url

And smash "Authorize app".

If authorized, redirected to your config.redirect_uri.
Check CODE in Twitter's response.

e.g. https://example.com/twitter/callback?state=***&code=*****

Step4. Fetch an access token

token = TwitterTweetBot.fetch_token('<CODE>', authorization.code_verifier)
# =>
#  #<TwitterTweetBot::Entity::Token
#   @access_token="<YOUR_ACCESS_TOKEN>",
#   @expires_in=7200,
#   @refresh_token="<YOUR_REFRESH_TOKEN>",
#   @scope="tweet.write users.read tweet.read offline.access",
#   @token_type="bearer">

Step5. Post a tweet

TwitterTweetBot.post_tweet(token.access_token, 'Yeah!')
# =>
#  #<TwitterTweetBot::Entity::Tweet
#   @edit_history_tweet_ids=["0123456789"],
#   @id="0123456789",
#   @text="Yeah!">
TwitterTweetBot.post_tweet(token.access_token, 'Yeah! Yeah!') do |params|
  params.reply = { in_reply_to_tweet_id: '*******************' }
end

Ex. Refresh an access token (required 'offline.access' in scopes)

TwitterTweetBot.refresh_token(token.refresh_token)

Caching

TwitterTweetBot can cache follow variables automatically in any store (like Rails.cache).

  • code_verifier
  • state
  • access_token
  • refresh_token

If needed, require 'twitter_tweet_bot/cache'.

require 'twitter_tweet_bot/cache'

TwitterTweetBot.post_tweet('Yeah!')
Details

Step1. Configuration

require 'twitter_tweet_bot/cache'

TwitterTweetBot.configure do |config|
  # ...

  # Any Cache Store (required `#write(key, value)` and `#read(key)` implementation).
  config.cache_provider = ActiveSupport::Cache.lookup_store(:file_store, '../tmp/cache')
end

Step2. Issue an authorization url

# `code_verifier` and `state` will be cached.
TwitterTweetBot.authorize

Step3. Fetch an access token

# `access_token` and `refresh_token` will be cached.
TwitterTweetBot.fetch_token('<CODE>')

Don't need to pass code_verifier.
(resolved from cache)

Step4. Post a tweet

TwitterTweetBot.post_tweet('Yeah!')

Don't need to pass access_token.
(resolved from cache)

Ex. Check a cache

TwitterTweetBot.client.cache.read
# =>
#  { :code_verifier=>"*****", :state=>"***", :access_token=>"*****", :refresh_token=>"*****" }