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/purge_request.rb | |
parent | a7073881fed6ec3f46841da96380d4b5643393a2 (diff) | |
parent | 2a1e80d1917e26caf13a20c199f5333be51caac0 (diff) |
Merge branch 'purge-requests' into develop
Diffstat (limited to 'app/models/purge_request.rb')
-rw-r--r-- | app/models/purge_request.rb | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/app/models/purge_request.rb b/app/models/purge_request.rb new file mode 100644 index 000000000..9bf1a0641 --- /dev/null +++ b/app/models/purge_request.rb @@ -0,0 +1,41 @@ +# models/purge_request.rb: +# A queue of URLs to purge +# +# Copyright (c) 2008 UK Citizens Online Democracy. All rights reserved. +# Email: francis@mysociety.org; WWW: http://www.mysociety.org/ +# + +class PurgeRequest < ActiveRecord::Base + def self.purge_all + done_something = false + for item in PurgeRequest.all() + item.purge + done_something = true + end + return done_something + end + + def self.purge_all_loop + # Run purge_all in an endless loop, sleeping when there is nothing to do + while true + sleep_seconds = 1 + while !purge_all + sleep sleep_seconds + sleep_seconds *= 2 + sleep_seconds = 30 if sleep_seconds > 30 + end + end + end + + def purge + config = MySociety::Config.load_default() + varnish_url = config['VARNISH_HOST'] + result = quietly_try_to_purge(varnish_url, self.url) + if result == "200" + self.delete() + end + end +end + + + |