Skip to content

Commit

Permalink
Merge pull request #25543 from techhat/gcebootstrap
Browse files Browse the repository at this point in the history
Switch GCE to salt.utils.cloud.bootstrap()
  • Loading branch information
Mike Place committed Jul 20, 2015
2 parents 2240d84 + 1b325cf commit 2dc601c
Showing 1 changed file with 3 additions and 96 deletions.
99 changes: 3 additions & 96 deletions salt/cloud/clouds/gce.py
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,6 @@
from __future__ import absolute_import
import os
import re
import copy
import stat
import pprint
import logging
Expand Down Expand Up @@ -2119,101 +2118,9 @@ def create(vm_=None, call=None):
# node_data is a libcloud Node which is unsubscriptable
node_dict = show_instance(node_data.name, 'action')

if config.get_cloud_config_value('deploy', vm_, __opts__) is True:
deploy_script = script(vm_)
ssh_user, ssh_key = __get_ssh_credentials(vm_)
deploy_kwargs = {
'opts': __opts__,
'host': __get_host(node_data, vm_),
'username': ssh_user,
'key_filename': ssh_key,
'script': deploy_script.script,
'name': vm_['name'],
'tmp_dir': config.get_cloud_config_value(
'tmp_dir', vm_, __opts__, default='/tmp/.saltcloud'
),
'deploy_command': config.get_cloud_config_value(
'deploy_command', vm_, __opts__,
default='/tmp/.saltcloud/deploy.sh',
),
'start_action': __opts__['start_action'],
'parallel': __opts__['parallel'],
'sock_dir': __opts__['sock_dir'],
'conf_file': __opts__['conf_file'],
'minion_pem': vm_['priv_key'],
'minion_pub': vm_['pub_key'],
'keep_tmp': __opts__['keep_tmp'],
'preseed_minion_keys': vm_.get('preseed_minion_keys', None),
'sudo': config.get_cloud_config_value(
'sudo', vm_, __opts__, default=(ssh_user != 'root')
),
'sudo_password': config.get_cloud_config_value(
'sudo_password', vm_, __opts__, default=None
),
'tty': config.get_cloud_config_value(
'tty', vm_, __opts__, default=(ssh_user != 'root')
),
'display_ssh_output': config.get_cloud_config_value(
'display_ssh_output', vm_, __opts__, default=True
),
'script_args': config.get_cloud_config_value(
'script_args', vm_, __opts__
),
'script_env': config.get_cloud_config_value(
'script_env', vm_, __opts__
),
'minion_conf': salt.utils.cloud.minion_config(__opts__, vm_)
}

# Deploy salt-master files, if necessary
if config.get_cloud_config_value('make_master', vm_, __opts__) is True:
deploy_kwargs['make_master'] = True
deploy_kwargs['master_pub'] = vm_['master_pub']
deploy_kwargs['master_pem'] = vm_['master_pem']
master_conf = salt.utils.cloud.master_config(__opts__, vm_)
deploy_kwargs['master_conf'] = master_conf

if master_conf.get('syndic_master', None):
deploy_kwargs['make_syndic'] = True

deploy_kwargs['make_minion'] = config.get_cloud_config_value(
'make_minion', vm_, __opts__, default=True
)

# Store what was used to the deploy the VM
event_kwargs = copy.deepcopy(deploy_kwargs)
del event_kwargs['minion_pem']
del event_kwargs['minion_pub']
del event_kwargs['sudo_password']
if 'password' in event_kwargs:
del event_kwargs['password']
node_dict['deploy_kwargs'] = event_kwargs

salt.utils.cloud.fire_event(
'event',
'executing deploy script',
'salt/cloud/{0}/deploying'.format(vm_['name']),
{'kwargs': event_kwargs},
transport=__opts__['transport']
)

deployed = salt.utils.cloud.deploy_script(**deploy_kwargs)
if deployed:
log.info('Salt installed on {0}'.format(vm_['name']))
else:
log.error(
'Failed to start Salt on Cloud VM {0}'.format(
vm_['name']
)
)

salt.utils.cloud.fire_event(
'event',
'executed deploy script',
'salt/cloud/{0}/deployed'.format(vm_['name']),
{'kwargs': event_kwargs},
transport=__opts__['transport']
)
ssh_user, ssh_key = __get_ssh_credentials(vm_)
vm_['ssh_host'] = __get_host(node_data, vm_)
vm_['key_filename'] = ssh_key

log.info('Created Cloud VM {0[name]!r}'.format(vm_))
log.debug(
Expand Down

0 comments on commit 2dc601c

Please sign in to comment.