mirror of
https://github.com/kevingruesser/bootstrap-vz.git
synced 2025-08-24 15:36:27 +00:00

Up until now I didn't see the point of using spaces for indentation. However, the previous commit (a18bec3) was quite eye opening. Given that python is an indentation aware language, the amount of mistakes that went unnoticed because tabs and spaces were used at the same time (tabs for indentation and spaces for alignment) were unacceptable. E101,W191 have been re-enable in the tox flake8 checker and the documentation has been modified accordingly. The following files have been left as-is: * bootstrapvz/common/assets/extlinux/extlinux.conf * bootstrapvz/common/assets/init.d/expand-root * bootstrapvz/common/assets/init.d/generate-ssh-hostkeys * bootstrapvz/common/assets/init.d/squeeze/generate-ssh-hostkeys * bootstrapvz/plugins/docker_daemon/assets/init.d/docker * bootstrapvz/providers/ec2/assets/bin/growpart * bootstrapvz/providers/ec2/assets/grub.d/40_custom * bootstrapvz/providers/ec2/assets/init.d/ec2-get-credentials * bootstrapvz/providers/ec2/assets/init.d/ec2-run-user-data * docs/_static/taskoverview.coffee * docs/_static/taskoverview.less * tests/unit/subprocess.sh
49 lines
1.9 KiB
Python
49 lines
1.9 KiB
Python
from bootstrapvz.common import task_groups
|
|
from bootstrapvz.common.tasks import image
|
|
from bootstrapvz.common.tasks import loopback
|
|
from bootstrapvz.common.tasks import ssh
|
|
from bootstrapvz.common.tasks import volume
|
|
import tasks.api
|
|
import tasks.image
|
|
import tasks.network
|
|
import tasks.packages
|
|
|
|
|
|
def validate_manifest(data, validator, error):
|
|
import os.path
|
|
validator(data, os.path.join(os.path.dirname(__file__), 'manifest-schema.yml'))
|
|
|
|
keys = ['username', 'password', 'identity-domain']
|
|
if 'credentials' in data['provider']:
|
|
if not all(key in data['provider']['credentials'] for key in keys):
|
|
msg = 'All Oracle Compute Cloud credentials should be specified in the manifest'
|
|
error(msg, ['provider', 'credentials'])
|
|
if not data['provider'].get('container'):
|
|
msg = 'The container to which the image will be uploaded should be specified'
|
|
error(msg, ['provider'])
|
|
|
|
|
|
def resolve_tasks(taskset, manifest):
|
|
taskset.update(task_groups.get_standard_groups(manifest))
|
|
taskset.update(task_groups.ssh_group)
|
|
|
|
taskset.update([loopback.AddRequiredCommands,
|
|
loopback.Create,
|
|
image.MoveImage,
|
|
ssh.DisableRootLogin,
|
|
volume.Delete,
|
|
tasks.image.CreateImageTarball,
|
|
tasks.network.InstallDHCPCD,
|
|
tasks.packages.DefaultPackages,
|
|
])
|
|
|
|
if 'credentials' in manifest.provider:
|
|
taskset.add(tasks.api.Connect)
|
|
taskset.add(tasks.image.UploadImageTarball)
|
|
if manifest.provider.get('verify', False):
|
|
taskset.add(tasks.image.DownloadImageTarball)
|
|
taskset.add(tasks.image.CompareImageTarballs)
|
|
|
|
|
|
def resolve_rollback_tasks(taskset, manifest, completed, counter_task):
|
|
taskset.update(task_groups.get_standard_rollback_tasks(completed))
|