1
\$\begingroup\$

Is there a better way to do this? I'm kinda ending up having a lot of if statements.

if params[:custom_url] || params[:user_id]
 if !params[:user_id].blank?
 @user = User.find(params[:user_id]).first
 @url = @user.custom_url
 else
 @url = params[:custom_url]
 @user = User.where(:custom_url => @url).first
 end
end
Jamal
35.2k13 gold badges134 silver badges238 bronze badges
asked Aug 9, 2012 at 15:34
\$\endgroup\$
1
  • 1
    \$\begingroup\$ instead of !params[:user_id].blank?, you can write params[:user_id].present? which reads more nicely. \$\endgroup\$ Commented Aug 11, 2012 at 12:23

2 Answers 2

1
\$\begingroup\$

I typically chain scopes together like this:

Model:

def self.by_user_and_url(user_id, custom_url)
 by_user(user_id).by_custom_url(custom_url)
end
def self.by_user(user_id)
 user_id ? where(user_id: user_id) : scoped
end
def self.by_custom_url(custom_url)
 custom_url ? where(custom_url: custom_url) : scoped
end

Controller:

if params[:custom_url].present? || params[:user_id].present?
 @user = User.by_user_and_url(params[:user_id], params[:custom_url]).first
end

I'm not sure why you had two instance variables. The url can be pulled from the @user instance variable if you need it in your view.

answered Aug 23, 2012 at 6:11
\$\endgroup\$
1
\$\begingroup\$

Not a big fan of case..when:

@user = User.find_first(params[:user_id]) if params[:user_id]
@user ||= User.find_by_custom_url(@url)
@url = params[:custom_url] || @user.custom_url
Winston Ewert
30.7k4 gold badges52 silver badges79 bronze badges
answered Aug 10, 2012 at 22:49
\$\endgroup\$
2
  • 2
    \$\begingroup\$ At line 2, @url is going to be nil, so there's no sense using it as a param. \$\endgroup\$ Commented Aug 11, 2012 at 20:32
  • \$\begingroup\$ Line 1, wouldn't it be better to use if params[:user_id].present? \$\endgroup\$ Commented Feb 11, 2013 at 19:32

Your Answer

Draft saved
Draft discarded

Sign up or log in

Sign up using Google
Sign up using Email and Password

Post as a guest

Required, but never shown

Post as a guest

Required, but never shown

By clicking "Post Your Answer", you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.