Mercurial > rsstweet
diff app/controllers/tweets_controller.rb @ 245:2935c5e52a71
No more official twitter api
author | nanaya <me@nanaya.net> |
---|---|
date | Mon, 17 Jul 2023 04:23:09 +0900 |
parents | 4222343d9433 |
children | e2150dce4e90 |
line wrap: on
line diff
--- a/app/controllers/tweets_controller.rb Fri Jul 14 01:45:40 2023 +0900 +++ b/app/controllers/tweets_controller.rb Mon Jul 17 04:23:09 2023 +0900 @@ -1,39 +1,43 @@ class TweetsController < ApplicationController def index - return redirect if params[:id].present? || params[:name].present? + return redirect if params[:name].present? end def show return redirect if params[:id][/\D/].present? - client = Tweet.new(params[:id].to_i) - @user = client.user + @user = CachedFetch.user_by_id params[:id] + + if @user.nil? + head :not_found + return + end + + if @user[:protected] + head :forbidden + return + end return redirect if normalized_screen_name != params[:name] - @tweets = client.timeline - rescue Twitter::Error::Forbidden - head :forbidden - rescue Twitter::Error::NotFound - head :not_found - rescue Twitter::Error::Unauthorized - head :forbidden + @tweets = CachedFetch.timeline params[:id] + + head :not_found if @tweets.nil? end def redirect - @user ||= Tweet.new(params[:id].presence || params[:name]).user - redirect_to tweet_path(@user.id, normalized_screen_name) - rescue Twitter::Error::Forbidden - head :forbidden - rescue Twitter::Error::NotFound - head :not_found - rescue Twitter::Error::Unauthorized - head :forbidden + @user ||= CachedFetch.user_by_username(params[:name]) + + if @user.nil? + head :not_found + else + redirect_to tweet_path(@user[:id], normalized_screen_name) + end end private def normalized_screen_name - @user.screen_name.presence || '_' + @user[:username].presence || '_' end end