One subdomain per each user blog?

Author Message

Carlos Revillo

Saturday 25 October 2008 7:38:09 am

Hi.

We're working in a community site. Registered users can create a blog by themselves.
When the blog is created, blog can be reached at http://www.domain.com/Blogs/username.

But customer wants these blogs can be reached at http://username.domain.com.

I don't really know if this can be suitable with eZ.

I'm working with hostmatchtype=map for this site, so solution here could be like this...

- there's an extension to create blogs.
- when a user creates another one, we need to created a new siteaccess for this blog (?)
in this new siteaccess we will need to setup db connection and also root node for it (pointing to the new blog node created at the content tree...)
we will also need to add lines to HostMatchMapItems setting. Something like
HostMatchMapItems[]=user1;user1

but now my doubts.
i don't think the best option is modifying settings/override file... i'm afraid that something could fail and maybe settings/override could became empty or something. we'll get the ez installation process then...

i don't think that having a siteacces per user could be the best option. suppose we have 10.000 users and a blog per each... we will have 10.000 siteaccess... that could be crazy...

Do you have any other ideas here?
Thank you

Andrew Duck

Saturday 25 October 2008 11:18:28 am

Hi Carlos,

It depends whether each new blog receives it's own database, or whether you are happy to house all content objects within your instance and use roles and privileges to lock down what they can edit.

If everyone needs separate databases, then custom siteaccesses is the only way forward. In which case check out HostMatchType, you can do element, text and regular expression matching to prevent making changes to override.ini. It's probably safer to match than having some automated process editing your override file.

If you don't need separate databases, then you could do some server side redirection using apache rewrite rules to map subdomains to the appropriate path. The rest can then be taken care of with roles and policies.

Regards,
Andrew.

Andrew Duck, Executive Director, Quiqcorp Limited
eZ Certified Developer and Trainer.
Member of the Community Project Board
http://quiqcorp.com | http://twitter.com/andrewduck

Carlos Revillo

Saturday 25 October 2008 12:07:21 pm

Thank you Andrew.

i don't need separate databases for the blogs. I've tried some rewrite rules... d
if i do something like

RewriteCond %{HTTP_HOST} ^(www\.)?username\.domain\.com
RewriteRule .* /Blogs/username [L] 

it works perfectly, but if the user types in browser http://username.domain.com he will be redirected to http://www.domain.com/Blogs/username. You will get this in browser. customer doesn't want that the url changes. he always wants to see username.domain.com/blablalb in browser.

If i do the "reverse way", like

redirectMatch 301 ^/Blogs/username(.+)$ http://username.domain.com

then, when visitor goes to a blog user he will be redirected to http://userdomain.domain.com as expected, but i need to add a hostMatchItem line to map default page of this userdomain.com to a node. and also i will need to create a siteaccess for this domain...

am i missing something here?
thanks again.

Andrew Duck

Saturday 25 October 2008 12:55:37 pm

Hi Carlos,

You should be able to get it working with mod_rewrite, provided you only use relative urls for the blog templates. Absolute urls generated inside templates would not be aware of your mod_rewrite implementation.

Another alternative, and perhaps more solid would be to look at the mod_proxy implementation in Apache.

Andrew Duck, Executive Director, Quiqcorp Limited
eZ Certified Developer and Trainer.
Member of the Community Project Board
http://quiqcorp.com | http://twitter.com/andrewduck

Carlos Revillo

Saturday 25 October 2008 1:17:08 pm

thanks Andrew.

i'm not really an expert with apache. i think i would try with mod_rewrite... but i don't completely understand you with "provided you only use relative urls for the blog templates. "...
could you please clarify me this?
thanks for your time.

Andrew Duck

Saturday 25 October 2008 11:54:38 pm

Absolute urls will include the domain name in the href tag, which would introduce complexity as it would likely point to mydomain.com rather than username.mydomain.com, which pushes you back to the wrong style of URL.

I haven't had chance to sit down and try it out, but I imagine you could:

Catch incoming request for "username.mydomain.com", rewrite it is mydomain.com/Blogs/username, without a redirect. This should preserve the original requested URL "username.mydomain.com" in the browser address bar.

The issue you run into now is that you have to catch the links to blog posts, and ensure they are properly handled. If they are in the format "mydomain.com/Blogs/username/my-post" then you need to rewrite your templates. You have two options.

1. You could try and use the template language to evaluate the HTTP_HOST and provide the appropriate domain in an absolute URL, OR

2. You could use relative urls, ie "/Blogs/username/my-post" (preferred I think)

At that point when you click on a link it should request "username.mydomain.com/Blogs/username/my-post" which you can catch with your rewrite rule.

One thing you likely cannot do with the above system, is force a redirect on an incoming request for "mydomain.com/Blogs/username" and redirect it to "username.mydomain.com" or you will end up in an endless loop of redirects with a nice 500 error from Apache.

You will have to live with the fact that mydomain.com/Blogs/username/my-post is accessible, it has to be to handle requests for your rewrite rule anyway, but your subdomains should work for the blog and deeper links.

Andrew Duck, Executive Director, Quiqcorp Limited
eZ Certified Developer and Trainer.
Member of the Community Project Board
http://quiqcorp.com | http://twitter.com/andrewduck

Carlos Revillo

Sunday 26 October 2008 3:31:04 am

Andrew, thanks a lot for your wonderful explanation.

I'm not really an expert in apache, so i'm going to do some searching for getting redirects from username.domain to domain/Blogs/username preserving the url.

If we have to live with also urls like /Blogs/username we'll do like this. anyway, i'll need to talk with our seo people because maybe we'll get duplicate content for Google, and it seems Google doesn't like this...

But this is other part.

If customer doesn't want like this, i'll tell about the dander of writing the settings/override/site.ini.append.php from a php file...

thank you again.

Andrew Duck

Sunday 26 October 2008 3:55:29 am

Duplicate content could be an unwanted side effect, not sure how subdomains play into that space.

I wouldn't advise automatically writing to your override/site.ini.append.php, but with HostMatchType it isn't necessary. Use text, element or regular expression matching instead of map.

It still leaves you with potentially 10,000 siteaccesses, but you don't have 10,000 entries in override/site.ini.append.php which is nice.

If you head down that path, you can of course work with IndexPage to set relative content tree roots for your blog siteaccesses which is a nicer way to work, but I haven't tested out the performance of element of regular expression matching against 10,000 siteaccesses and a large number of concurrent users. It is definitely something I would encourage you simulate before pushing too far into development to ensure you don't hit scalability or performance issues.

Andrew Duck, Executive Director, Quiqcorp Limited
eZ Certified Developer and Trainer.
Member of the Community Project Board
http://quiqcorp.com | http://twitter.com/andrewduck

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 19 2025 07:08:06
Script start
Timing: Jan 19 2025 07:08:06
Module start 'layout'
Timing: Jan 19 2025 07:08:06
Module start 'content'
Timing: Jan 19 2025 07:08:06
Module end 'content'
Timing: Jan 19 2025 07:08:06
Script end

Main resources:

Total runtime0.0162 sec
Peak memory usage2,048.0000 KB
Database Queries3

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0061 590.2344152.6250
Module start 'layout' 0.00610.0034 742.859439.4453
Module start 'content' 0.00950.0045 782.3047101.4609
Module end 'content' 0.01400.0021 883.765646.3047
Script end 0.0161  930.0703 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.002616.3165140.0002
Check MTime0.00138.2428140.0001
Mysql Total
Database connection0.00074.538210.0007
Mysqli_queries0.003622.069030.0012
Looping result0.00000.092610.0000
Template Total0.001810.910.0018
Template load0.00106.314010.0010
Template processing0.00074.532310.0007
Override
Cache load0.00074.514610.0007
General
dbfile0.00021.399580.0000
String conversion0.00000.042640.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs