Index: third_party/boto/boto/pyami/copybot.py |
diff --git a/third_party/boto/boto/pyami/copybot.py b/third_party/boto/boto/pyami/copybot.py |
new file mode 100644 |
index 0000000000000000000000000000000000000000..ed397cb761b62506408c016af05861341abfa171 |
--- /dev/null |
+++ b/third_party/boto/boto/pyami/copybot.py |
@@ -0,0 +1,97 @@ |
+# Copyright (c) 2006,2007 Mitch Garnaat http://garnaat.org/ |
+# |
+# Permission is hereby granted, free of charge, to any person obtaining a |
+# copy of this software and associated documentation files (the |
+# "Software"), to deal in the Software without restriction, including |
+# without limitation the rights to use, copy, modify, merge, publish, dis- |
+# tribute, sublicense, and/or sell copies of the Software, and to permit |
+# persons to whom the Software is furnished to do so, subject to the fol- |
+# lowing conditions: |
+# |
+# The above copyright notice and this permission notice shall be included |
+# in all copies or substantial portions of the Software. |
+# |
+# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
+# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL- |
+# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT |
+# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, |
+# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
+# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS |
+# IN THE SOFTWARE. |
+# |
+import boto |
+from boto.pyami.scriptbase import ScriptBase |
+import os, StringIO |
+ |
+class CopyBot(ScriptBase): |
+ |
+ def __init__(self): |
+ ScriptBase.__init__(self) |
+ self.wdir = boto.config.get('Pyami', 'working_dir') |
+ self.log_file = '%s.log' % self.instance_id |
+ self.log_path = os.path.join(self.wdir, self.log_file) |
+ boto.set_file_logger(self.name, self.log_path) |
+ self.src_name = boto.config.get(self.name, 'src_bucket') |
+ self.dst_name = boto.config.get(self.name, 'dst_bucket') |
+ self.replace = boto.config.getbool(self.name, 'replace_dst', True) |
+ s3 = boto.connect_s3() |
+ self.src = s3.lookup(self.src_name) |
+ if not self.src: |
+ boto.log.error('Source bucket does not exist: %s' % self.src_name) |
+ dest_access_key = boto.config.get(self.name, 'dest_aws_access_key_id', None) |
+ if dest_access_key: |
+ dest_secret_key = boto.config.get(self.name, 'dest_aws_secret_access_key', None) |
+ s3 = boto.connect(dest_access_key, dest_secret_key) |
+ self.dst = s3.lookup(self.dst_name) |
+ if not self.dst: |
+ self.dst = s3.create_bucket(self.dst_name) |
+ |
+ def copy_bucket_acl(self): |
+ if boto.config.get(self.name, 'copy_acls', True): |
+ acl = self.src.get_xml_acl() |
+ self.dst.set_xml_acl(acl) |
+ |
+ def copy_key_acl(self, src, dst): |
+ if boto.config.get(self.name, 'copy_acls', True): |
+ acl = src.get_xml_acl() |
+ dst.set_xml_acl(acl) |
+ |
+ def copy_keys(self): |
+ boto.log.info('src=%s' % self.src.name) |
+ boto.log.info('dst=%s' % self.dst.name) |
+ try: |
+ for key in self.src: |
+ if not self.replace: |
+ exists = self.dst.lookup(key.name) |
+ if exists: |
+ boto.log.info('key=%s already exists in %s, skipping' % (key.name, self.dst.name)) |
+ continue |
+ boto.log.info('copying %d bytes from key=%s' % (key.size, key.name)) |
+ prefix, base = os.path.split(key.name) |
+ path = os.path.join(self.wdir, base) |
+ key.get_contents_to_filename(path) |
+ new_key = self.dst.new_key(key.name) |
+ new_key.set_contents_from_filename(path) |
+ self.copy_key_acl(key, new_key) |
+ os.unlink(path) |
+ except: |
+ boto.log.exception('Error copying key: %s' % key.name) |
+ |
+ def copy_log(self): |
+ key = self.dst.new_key(self.log_file) |
+ key.set_contents_from_filename(self.log_path) |
+ |
+ def main(self): |
+ fp = StringIO.StringIO() |
+ boto.config.dump_safe(fp) |
+ self.notify('%s (%s) Starting' % (self.name, self.instance_id), fp.getvalue()) |
+ if self.src and self.dst: |
+ self.copy_keys() |
+ if self.dst: |
+ self.copy_log() |
+ self.notify('%s (%s) Stopping' % (self.name, self.instance_id), |
+ 'Copy Operation Complete') |
+ if boto.config.getbool(self.name, 'exit_on_completion', True): |
+ ec2 = boto.connect_ec2() |
+ ec2.terminate_instances([self.instance_id]) |
+ |