| Index: tools/telemetry/third_party/gsutilz/third_party/boto/boto/pyami/bootstrap.py
|
| diff --git a/tools/telemetry/third_party/gsutilz/third_party/boto/boto/pyami/bootstrap.py b/tools/telemetry/third_party/gsutilz/third_party/boto/boto/pyami/bootstrap.py
|
| deleted file mode 100644
|
| index 82c2822edd9a15d958c8325b1c7df94e0197ac44..0000000000000000000000000000000000000000
|
| --- a/tools/telemetry/third_party/gsutilz/third_party/boto/boto/pyami/bootstrap.py
|
| +++ /dev/null
|
| @@ -1,134 +0,0 @@
|
| -# 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 os
|
| -import boto
|
| -from boto.utils import get_instance_metadata, get_instance_userdata
|
| -from boto.pyami.config import Config, BotoConfigPath
|
| -from boto.pyami.scriptbase import ScriptBase
|
| -import time
|
| -
|
| -class Bootstrap(ScriptBase):
|
| - """
|
| - The Bootstrap class is instantiated and run as part of the PyAMI
|
| - instance initialization process. The methods in this class will
|
| - be run from the rc.local script of the instance and will be run
|
| - as the root user.
|
| -
|
| - The main purpose of this class is to make sure the boto distribution
|
| - on the instance is the one required.
|
| - """
|
| -
|
| - def __init__(self):
|
| - self.working_dir = '/mnt/pyami'
|
| - self.write_metadata()
|
| - super(Bootstrap, self).__init__()
|
| -
|
| - def write_metadata(self):
|
| - fp = open(os.path.expanduser(BotoConfigPath), 'w')
|
| - fp.write('[Instance]\n')
|
| - inst_data = get_instance_metadata()
|
| - for key in inst_data:
|
| - fp.write('%s = %s\n' % (key, inst_data[key]))
|
| - user_data = get_instance_userdata()
|
| - fp.write('\n%s\n' % user_data)
|
| - fp.write('[Pyami]\n')
|
| - fp.write('working_dir = %s\n' % self.working_dir)
|
| - fp.close()
|
| - # This file has the AWS credentials, should we lock it down?
|
| - # os.chmod(BotoConfigPath, stat.S_IREAD | stat.S_IWRITE)
|
| - # now that we have written the file, read it into a pyami Config object
|
| - boto.config = Config()
|
| - boto.init_logging()
|
| -
|
| - def create_working_dir(self):
|
| - boto.log.info('Working directory: %s' % self.working_dir)
|
| - if not os.path.exists(self.working_dir):
|
| - os.mkdir(self.working_dir)
|
| -
|
| - def load_boto(self):
|
| - update = boto.config.get('Boto', 'boto_update', 'svn:HEAD')
|
| - if update.startswith('svn'):
|
| - if update.find(':') >= 0:
|
| - method, version = update.split(':')
|
| - version = '-r%s' % version
|
| - else:
|
| - version = '-rHEAD'
|
| - location = boto.config.get('Boto', 'boto_location', '/usr/local/boto')
|
| - self.run('svn update %s %s' % (version, location))
|
| - elif update.startswith('git'):
|
| - location = boto.config.get('Boto', 'boto_location', '/usr/share/python-support/python-boto/boto')
|
| - num_remaining_attempts = 10
|
| - while num_remaining_attempts > 0:
|
| - num_remaining_attempts -= 1
|
| - try:
|
| - self.run('git pull', cwd=location)
|
| - num_remaining_attempts = 0
|
| - except Exception as e:
|
| - boto.log.info('git pull attempt failed with the following exception. Trying again in a bit. %s', e)
|
| - time.sleep(2)
|
| - if update.find(':') >= 0:
|
| - method, version = update.split(':')
|
| - else:
|
| - version = 'master'
|
| - self.run('git checkout %s' % version, cwd=location)
|
| - else:
|
| - # first remove the symlink needed when running from subversion
|
| - self.run('rm /usr/local/lib/python2.5/site-packages/boto')
|
| - self.run('easy_install %s' % update)
|
| -
|
| - def fetch_s3_file(self, s3_file):
|
| - try:
|
| - from boto.utils import fetch_file
|
| - f = fetch_file(s3_file)
|
| - path = os.path.join(self.working_dir, s3_file.split("/")[-1])
|
| - open(path, "w").write(f.read())
|
| - except:
|
| - boto.log.exception('Problem Retrieving file: %s' % s3_file)
|
| - path = None
|
| - return path
|
| -
|
| - def load_packages(self):
|
| - package_str = boto.config.get('Pyami', 'packages')
|
| - if package_str:
|
| - packages = package_str.split(',')
|
| - for package in packages:
|
| - package = package.strip()
|
| - if package.startswith('s3:'):
|
| - package = self.fetch_s3_file(package)
|
| - if package:
|
| - # if the "package" is really a .py file, it doesn't have to
|
| - # be installed, just being in the working dir is enough
|
| - if not package.endswith('.py'):
|
| - self.run('easy_install -Z %s' % package, exit_on_error=False)
|
| -
|
| - def main(self):
|
| - self.create_working_dir()
|
| - self.load_boto()
|
| - self.load_packages()
|
| - self.notify('Bootstrap Completed for %s' % boto.config.get_instance('instance-id'))
|
| -
|
| -if __name__ == "__main__":
|
| - # because bootstrap starts before any logging configuration can be loaded from
|
| - # the boto config files, we will manually enable logging to /var/log/boto.log
|
| - boto.set_file_logger('bootstrap', '/var/log/boto.log')
|
| - bs = Bootstrap()
|
| - bs.main()
|
|
|