bootstrap-vz/providers/ec2/__init__.py

109 lines
3.9 KiB
Python
Raw Normal View History

2013-05-16 08:00:28 +02:00
from manifest import Manifest
import logging
from tasks import packages
from tasks import connection
from tasks import host
2013-07-07 20:28:24 +02:00
from tasks import ami
from tasks import ebs
from tasks import loopback
2013-06-27 00:11:09 +02:00
from tasks import filesystem
2013-06-27 23:26:29 +02:00
from tasks import bootstrap
2013-07-01 22:52:54 +02:00
from tasks import locale
from common.tasks import apt
2013-07-01 23:15:49 +02:00
from tasks import boot
from common.tasks import boot as common_boot
2013-07-01 23:41:22 +02:00
from tasks import security
2013-07-01 23:54:18 +02:00
from tasks import network
2013-07-07 14:58:03 +02:00
from tasks import initd
2013-07-07 16:59:12 +02:00
from tasks import cleanup
2013-05-16 08:00:28 +02:00
def initialize():
# Regardless of of loglevel, we don't want boto debug stuff, it's very noisy
logging.getLogger('boto').setLevel(logging.INFO)
def tasks(tasklist, manifest):
2013-07-01 22:38:33 +02:00
tasklist.add(packages.HostPackages(),
packages.ImagePackages(),
host.CheckPackages(),
connection.GetCredentials(),
host.GetInfo(),
2013-07-07 20:28:24 +02:00
ami.AMIName(),
connection.Connect(),
filesystem.FormatVolume(),
filesystem.CreateMountDir(),
filesystem.MountVolume(),
bootstrap.Bootstrap(),
2013-07-01 22:38:33 +02:00
filesystem.MountSpecials(),
2013-07-01 22:52:54 +02:00
locale.GenerateLocale(),
locale.SetTimezone(),
apt.DisableDaemonAutostart(),
2013-07-01 22:52:54 +02:00
apt.AptSources(),
2013-07-01 23:15:49 +02:00
apt.AptUpgrade(),
2013-07-01 23:25:11 +02:00
boot.ConfigureGrub(),
2013-07-07 13:02:04 +02:00
filesystem.ModifyFstab(),
common_boot.BlackListModules(),
common_boot.DisableGetTTYs(),
2013-07-01 23:41:22 +02:00
security.EnableShadowConfig(),
security.DisableSSHPasswordAuthentication(),
2013-07-01 23:54:18 +02:00
security.DisableSSHDNSLookup(),
network.RemoveDNSInfo(),
network.ConfigureNetworkIF(),
2013-07-07 14:58:03 +02:00
network.ConfigureDHCP(),
initd.ResolveInitScripts(),
2013-07-07 16:59:12 +02:00
initd.InstallInitScripts(),
cleanup.ClearMOTD(),
cleanup.ShredHostkeys(),
2013-07-07 18:03:49 +02:00
cleanup.CleanTMP(),
apt.PurgeUnusedPackages(),
apt.AptClean(),
apt.EnableDaemonAutostart(),
filesystem.UnmountSpecials(),
filesystem.UnmountVolume(),
filesystem.DeleteMountDir(),
ami.RegisterAMI())
if manifest.bootstrapper['tarball']:
tasklist.add(bootstrap.MakeTarball())
backing_specific_tasks = {'ebs': [ebs.Create(),
ebs.Attach(),
ebs.Detach(),
ebs.Snapshot(),
ebs.Delete()],
's3': [loopback.Create(),
loopback.Attach(),
loopback.Detach(),
ami.BundleImage(),
ami.UploadImage(),
loopback.Delete(),
ami.RemoveBundle()]}
tasklist.add(*backing_specific_tasks.get(manifest.volume['backing'].lower()))
filesystem_specific_tasks = {'xfs': [filesystem.AddXFSProgs()],
'ext2': [filesystem.TuneVolumeFS()],
'ext3': [filesystem.TuneVolumeFS()],
'ext4': [filesystem.TuneVolumeFS()]}
tasklist.add(*filesystem_specific_tasks.get(manifest.volume['filesystem'].lower()))
def rollback_tasks(tasklist, tasks_completed, manifest):
completed = [type(task) for task in tasks_completed]
def counter_task(task, counter):
if task in completed and counter not in completed:
tasklist.add(counter())
if manifest.volume['backing'].lower() == 'ebs':
counter_task(ebs.Create, ebs.Delete)
counter_task(ebs.Attach, ebs.Detach)
if manifest.volume['backing'].lower() == 's3':
counter_task(loopback.Create, loopback.Delete)
counter_task(loopback.Attach, loopback.Detach)
counter_task(filesystem.CreateMountDir, filesystem.DeleteMountDir)
counter_task(filesystem.MountVolume, filesystem.UnmountVolume)
2013-07-01 20:48:51 +02:00
counter_task(filesystem.MountSpecials, filesystem.UnmountSpecials)