Adding the ability to set a robots.txt for each site (ticket #87)

This commit is contained in:
did 2011-07-05 22:34:15 +02:00
parent 43670714b9
commit 1a62d8f5ad
12 changed files with 69 additions and 10 deletions

View File

@ -0,0 +1,18 @@
module Admin
class RobotsController < ActionController::Base
include Locomotive::Routing::SiteDispatcher
include Locomotive::Render
before_filter :require_site
respond_to :txt
def show
template = Liquid::Template.parse(current_site.robots_txt)
render :text => template.render('request_host' => self.request.host.downcase)
end
end
end

View File

@ -10,6 +10,7 @@ class Site
## fields ## ## fields ##
field :name field :name
field :robots_txt
## associations ## ## associations ##
references_many :pages, :validate => false references_many :pages, :validate => false

View File

@ -66,3 +66,11 @@
- else - else
.role .role
%em.locked= t("admin.memberships.roles.#{membership.role}") %em.locked= t("admin.memberships.roles.#{membership.role}")
- if can?(:manage, current_site)
= f.foldable_inputs :name => :robots_txt do
= f.custom_input :robots_txt, :css => 'code full', :with_label => false do
= f.label :robots_txt
%code{ :class => 'html' }
= f.text_area :robots_txt, :class => 'small'

View File

@ -45,6 +45,7 @@ javascripts:
- public/javascripts/admin/content_types.js - public/javascripts/admin/content_types.js
site: site:
- public/javascripts/admin/site.js - public/javascripts/admin/site.js
- public/javascripts/admin/plugins/codemirror/codemirror.min.js
import: import:
- public/javascripts/admin/plugins/json2.js - public/javascripts/admin/plugins/json2.js
- public/javascripts/admin/plugins/smartupdater.js - public/javascripts/admin/plugins/smartupdater.js

View File

@ -5,6 +5,7 @@ en:
advanced_options: Advanced options advanced_options: Advanced options
meta: SEO Metadata meta: SEO Metadata
seo: SEO settings seo: SEO settings
robots_txt: Robots.txt file
code: Code code: Code
raw_template: Template raw_template: Template
credentials: Credentials credentials: Credentials
@ -67,6 +68,7 @@ en:
meta_keywords: "Meta keywords used within the head tag of the page. They are separated by a comma. Required for SEO." meta_keywords: "Meta keywords used within the head tag of the page. They are separated by a comma. Required for SEO."
meta_description: "Meta description used within the head tag of the page. Required for SEO." meta_description: "Meta description used within the head tag of the page. Required for SEO."
domain_name: "ex: locomotiveapp.org" domain_name: "ex: locomotiveapp.org"
robots_txt: "Content of the <span class='code'>/robots.txt</span> file. Check the following <a href='http://www.w3.org/TR/html4/appendix/notes.html#h-B.4.1.1'>url</a> for more information."
theme_asset: theme_asset:
slug: "You do not need to add the extension file (.css or .js)" slug: "You do not need to add the extension file (.css or .js)"
edit: edit:

View File

@ -5,6 +5,7 @@ fr:
advanced_options: Options avancées advanced_options: Options avancées
meta: SEO Metadata meta: SEO Metadata
seo: Paramètres SEO seo: Paramètres SEO
robots_txt: Fichier Robots.txt
code: Code code: Code
raw_template: Gabarit raw_template: Gabarit
credentials: Informations de connexion credentials: Informations de connexion

View File

@ -60,6 +60,9 @@ Rails.application.routes.draw do
# sitemap # sitemap
match '/sitemap.xml' => 'admin/sitemaps#show', :format => 'xml' match '/sitemap.xml' => 'admin/sitemaps#show', :format => 'xml'
# robots.txt
match '/robots.txt' => 'admin/robots#show', :format => 'txt'
# magic urls # magic urls
match '/' => 'admin/rendering#show' match '/' => 'admin/rendering#show'
match '*path/edit' => 'admin/rendering#show', :defaults => { :editing => true } match '*path/edit' => 'admin/rendering#show', :defaults => { :editing => true }

View File

@ -25,4 +25,5 @@ Here is a pretty exhaustive list of what the BIG MERGE includes:
- slight modifications on forms: separator between fields, text shadow, error message redesigned, ...etc - slight modifications on forms: separator between fields, text shadow, error message redesigned, ...etc
- quick link to edit directly a model from the submenu - quick link to edit directly a model from the submenu
- new sites picker (if the multi_sites mode is enabled and correctly set up) - new sites picker (if the multi_sites mode is enabled and correctly set up)
- the robots.txt can be edited directly from the back-office (site settings).
- a lot of internal refactoring as well as a ton of bug corrections - a lot of internal refactoring as well as a ton of bug corrections

View File

@ -0,0 +1,22 @@
Feature: Robots
As a designer
I want to be able to define a robots.txt file for my site
Background:
Given I have the site: "test site" set up
Scenario: Simple robots text
Given a robot_txt set to "robots text value"
When I view the rendered page at "/robots.txt"
Then the rendered output should look like:
"""
robots text value
"""
Scenario: Robots.txt should provide access to request_host
Given a robot_txt set to "host: {{request_host}}"
When I view the rendered page at "/robots.txt"
Then the rendered output should look like:
"""
host: test.example.com
"""

View File

@ -22,3 +22,9 @@ Then /^I should be a administrator of the "([^"]*)" site$/ do |name|
m = site.memberships.detect { |m| m.account_id == @admin._id && m.admin? } m = site.memberships.detect { |m| m.account_id == @admin._id && m.admin? }
m.should_not be_nil m.should_not be_nil
end end
# sets the robot_txt for a site
Given /^a robot_txt set to "([^"]*)"$/ do |value|
@site.update_attributes(:robots_txt => value)
end

View File

@ -1,5 +0,0 @@
# See http://www.robotstxt.org/wc/norobots.html for documentation on how to use the robots.txt file
#
# To ban all spiders from the entire site uncomment the next two lines:
# User-Agent: *
# Disallow: /

View File

@ -126,6 +126,7 @@ form.formtastic fieldset ol li.date input {
form.formtastic fieldset ol li p.inline-hints { margin-left: 20%; } form.formtastic fieldset ol li p.inline-hints { margin-left: 20%; }
form.formtastic fieldset ol li p.inline-hints a { color: #1f82bc; } form.formtastic fieldset ol li p.inline-hints a { color: #1f82bc; }
form.formtastic fieldset ol li p.inline-hints .code { background-color: #c8cad0; color: #5E5F64; text-shadow: rgba(255, 255, 255, 0.8) 0px 1px; }
form.formtastic fieldset ol li code { display: block; border: 1px solid #d1d6e6; margin: 10px 20px 0 20px; } form.formtastic fieldset ol li code { display: block; border: 1px solid #d1d6e6; margin: 10px 20px 0 20px; }
form.formtastic fieldset ol li code.nude textarea { form.formtastic fieldset ol li code.nude textarea {
@ -172,6 +173,10 @@ form.formtastic fieldset ol .more a.picture {
background: transparent url(/images/admin/icons/asset_add.png) no-repeat left 1px; background: transparent url(/images/admin/icons/asset_add.png) no-repeat left 1px;
} }
form.formtastic fieldset li.full .inline-errors, form.formtastic fieldset li.full .inline-hints {
margin-left: 20px;
}
/* ___ pages ___ */ /* ___ pages ___ */
form.formtastic fieldset ol li.path em { form.formtastic fieldset ol li.path em {
@ -525,10 +530,6 @@ form.formtastic fieldset.email li.full input {
margin-left: 20px; margin-left: 20px;
} }
form.formtastic fieldset.email li.full .inline-errors {
margin-left: 20px;
}
form.formtastic fieldset.memberships ol li .role { form.formtastic fieldset.memberships ol li .role {
position: absolute; position: absolute;
top: 2px; top: 2px;