I’m developing a Rails app that by default sets up user accounts to a subdomain of their choosing. As an option, they will be able to map their own full domain to their account.
So far this is how I have things set up. I am using subdomain-fu to power the routing:
# routes.rb
map.with_options :conditions => {:subdomain => true} do |app|
app.resources # User's application routes are all mapped here
end
map.with_options :conditions => {:subdomain => false} do |www|
www.resources # Public-facing sales website routes are mapped here
end
In addition to that, I am using the method described here to get the account being accessed, via subdomain or full domain:
before_filter :set_current_account
def set_current_account
if request.host.ends_with? current_domain
# via subdomain
@current_club = Club.find_by_subdomain(current_subdomain)
else
# via full domain
@current_club = Club.find_by_mapped_domain(request.host)
end
end
I haven’t got very far down the process of building this yet, but already I can see I am going to run into problems with routing. If request.host is some random.com domain then subdomain-fu is not going to route the appropriate routes?
I’m assuming this isn’t that unusual a problem, so can anyone share how they have tackled this problem, or how I would configure my routes to do what I need it to?
I ran into this problem, trying to do too much within a single application. You’ll start doing conditionals in very odd places that you shouldn’t have to. I decided to have 2 separate Rails apps that have the wildcard domain point to the User’s application, then having
www.domain.comanddomain.compoint to the public facing side. I know this doesn’t quite “answer” your question directly.Small code smell there that I can help you fix, if you add this to the top of that method:
It won’t make a query for each time you try to access
@current_club, it will return the result you already returned.