aboutsummaryrefslogtreecommitdiffstats
path: root/lib/active_file
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2017-07-03 16:01:11 +0200
committerDavid Heinemeier Hansson <david@loudthinking.com>2017-07-03 16:01:11 +0200
commit19a5191daae3d6083f906e81906905007daef1cb (patch)
tree9beed6abcca7f15d46fcf5a311d77e17c7a37e1b /lib/active_file
parent6d93b2dfe45b8542e2d4c00705f91157d4cf94bf (diff)
downloadrails-19a5191daae3d6083f906e81906905007daef1cb.tar.gz
rails-19a5191daae3d6083f906e81906905007daef1cb.tar.bz2
rails-19a5191daae3d6083f906e81906905007daef1cb.zip
Simple idea for a mirror site
Diffstat (limited to 'lib/active_file')
-rw-r--r--lib/active_file/sites/mirror_site.rb44
1 files changed, 44 insertions, 0 deletions
diff --git a/lib/active_file/sites/mirror_site.rb b/lib/active_file/sites/mirror_site.rb
new file mode 100644
index 0000000000..86dd906be7
--- /dev/null
+++ b/lib/active_file/sites/mirror_site.rb
@@ -0,0 +1,44 @@
+class ActiveFile::Sites::MirrorSite < ActiveFile::Site
+ attr_reader :sites
+
+ def initialize(sites:)
+ @sites = sites
+ end
+
+ def upload(key, data)
+ perform_across_sites :upload, key, data
+ end
+
+ def download(key)
+ sites.detect { |site| site.exist?(key) }.download(key)
+ end
+
+ def delete(key)
+ perform_across_sites :delete, key
+ end
+
+ def exists?(key)
+ perform_across_sites(:exists?, key).any?
+ end
+
+
+ def byte_size(key)
+ primary_site.byte_size(key)
+ end
+
+ def checksum(key)
+ primary_site.checksum(key)
+ end
+
+ private
+ def primary_site
+ sites.first
+ end
+
+ def perform_across_sites(method, **args)
+ # FIXME: Convert to be threaded
+ sites.collect do |site|
+ site.send method, **args
+ end
+ end
+end