Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8886443
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 14, 20262026-06-14T21:33:38+00:00 2026-06-14T21:33:38+00:00

I have a user model, that stores, amongst other things, the users address. When

  • 0

I have a user model, that stores, amongst other things, the users address. When creating an account (user_sessions controller) I only wish to validate the presence of their name, the address is optional.

When they upgrade their account (upgrade controller) i want to validate that that their full address is entered.

Is there an elegant way of having a conditional validation based on the controller?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-14T21:33:40+00:00Added an answer on June 14, 2026 at 9:33 pm

    Have you tried creating a new model that inherits from the old one. So you could have:

    class User < ActiveRecord::Base
      attr_accessible :name, :address
      validates_presence_of :name
    end
    
    class UpgradedUser < User
      validates_precense_of :address
    end
    

    Since it inherits from the User class, the UpgradedUser class has validations for both address and name. And this solution would still be only using one database table. Because they are still one table, you’d have to add a :account_status column or something to determine whether an account has been upgraded or not.

    In your upgraded_users controller you would have a standard update method:

    class upgraded_users_controller   
    
      def update
        @upgraded_user = UpgradedUser.find params[:id]
        respond_to do |format|
          if @upgraded_user.update_attributes params[:user]
            format.html { redirect_to @upgraded_user }
          end
        end
    

    This method will access the same User table just like the users_controller would, but its simply doing so through the UpgradedUser model instead, and therefore would check the validators on save for both name and address presence.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a simple user model that stores an email address, crypted_password, salt and
I have a User model that has the following default_scope: default_scope where(account_id: Account.current_account.id) If
I have a model that holds user address. This model has to have first_name
I have a a model that stores users: class SubItem(models.Model): created = models.DateTimeField(default=datetime.now) created_by
I have a video model that stores 'likes' as a manytomany field with User.
I have a User model that has many posts. Im trying to render the
I have a user model that requires the user to change their password every
I have a model that has a ForeignKey to the built-in user model in
I have a field on my User model that is protected because it determines
So I have a method in my User model that tries to determine if

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.