diff options
author | Seb Bacon <seb.bacon@gmail.com> | 2012-05-02 15:15:05 +0100 |
---|---|---|
committer | Seb Bacon <seb.bacon@gmail.com> | 2012-05-02 15:15:05 +0100 |
commit | d6a5e30665c9642b5d9977e1caf7f4f8a32f8b84 (patch) | |
tree | af4693ac9f8d878f3d6c83ede5b8c59e43147b13 /app/models/info_request.rb | |
parent | a7073881fed6ec3f46841da96380d4b5643393a2 (diff) | |
parent | 2a1e80d1917e26caf13a20c199f5333be51caac0 (diff) |
Merge branch 'purge-requests' into develop
Diffstat (limited to 'app/models/info_request.rb')
-rw-r--r-- | app/models/info_request.rb | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/app/models/info_request.rb b/app/models/info_request.rb index b5a1cd833..78121f5ea 100644 --- a/app/models/info_request.rb +++ b/app/models/info_request.rb @@ -23,6 +23,9 @@ require 'digest/sha1' class InfoRequest < ActiveRecord::Base + include ActionView::Helpers::UrlHelper + include ActionController::UrlWriter + strip_attributes! validates_presence_of :title, :message => N_("Please enter a summary of your request") @@ -453,7 +456,6 @@ public # An annotation (comment) is made def add_comment(body, user) comment = Comment.new - ActiveRecord::Base.transaction do comment.body = body comment.user = user @@ -1042,6 +1044,18 @@ public end return ret end + + before_save :purge_in_cache + def purge_in_cache + if !MySociety::Config.get('VARNISH_HOST').nil? && !self.id.nil? + # we only do this for existing info_requests (new ones have a nil id) + path = url_for(:controller => 'request', :action => 'show', :url_title => self.url_title, :only_path => true, :locale => :none) + req = PurgeRequest.new(:url => path, + :model => self.class.base_class.to_s, + :model_id => self.id) + req.save() + end + end end |