~justin-fathomdb/nova/justinsb-openstack-api-volumes

« back to all changes in this revision

Viewing changes to vendor/boto/boto/pyami/startup.py

  • Committer: Jesse Andrews
  • Date: 2010-05-28 06:05:26 UTC
  • Revision ID: git-v1:bf6e6e718cdc7488e2da87b21e258ccc065fe499
initial commit

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
# Copyright (c) 2006,2007 Mitch Garnaat http://garnaat.org/
 
2
#
 
3
# Permission is hereby granted, free of charge, to any person obtaining a
 
4
# copy of this software and associated documentation files (the
 
5
# "Software"), to deal in the Software without restriction, including
 
6
# without limitation the rights to use, copy, modify, merge, publish, dis-
 
7
# tribute, sublicense, and/or sell copies of the Software, and to permit
 
8
# persons to whom the Software is furnished to do so, subject to the fol-
 
9
# lowing conditions:
 
10
#
 
11
# The above copyright notice and this permission notice shall be included
 
12
# in all copies or substantial portions of the Software.
 
13
#
 
14
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
 
15
# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
 
16
# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
 
17
# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 
 
18
# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 
19
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 
20
# IN THE SOFTWARE.
 
21
#
 
22
import sys
 
23
import boto
 
24
from boto.utils import find_class
 
25
from boto import config
 
26
from boto.pyami.scriptbase import ScriptBase
 
27
 
 
28
 
 
29
class Startup(ScriptBase):
 
30
 
 
31
    def run_scripts(self):
 
32
        scripts = config.get('Pyami', 'scripts')
 
33
        if scripts:
 
34
            for script in scripts.split(','):
 
35
                script = script.strip(" ")
 
36
                try:
 
37
                    pos = script.rfind('.')
 
38
                    if pos > 0:
 
39
                        mod_name = script[0:pos]
 
40
                        cls_name = script[pos+1:]
 
41
                        cls = find_class(mod_name, cls_name)
 
42
                        boto.log.info('Running Script: %s' % script)
 
43
                        s = cls()
 
44
                        s.main()
 
45
                    else:
 
46
                        boto.log.warning('Trouble parsing script: %s' % script)
 
47
                except Exception:
 
48
                    boto.log.exception('Problem Running Script: %s' % script)
 
49
 
 
50
    def main(self):
 
51
        self.run_scripts()
 
52
        self.notify('Startup Completed for %s' % config.get('Instance', 'instance-id'))
 
53
 
 
54
if __name__ == "__main__":
 
55
    if not config.has_section('loggers'):
 
56
        boto.set_file_logger('startup', '/var/log/boto.log')
 
57
    sys.path.append(config.get('Pyami', 'working_dir'))
 
58
    su = Startup()
 
59
    su.main()