def _add_saltcloud_conf(manifest, cloud): saltcloud_conf = yaml.load( filesystem.read_file('cloudseed/current/salt/cloud')) if not saltcloud_conf: saltcloud_conf = {} ssh_interface = cloud.opts.get('ssh_interface', 'private_ips') interface_ips = { 'public_ips': cloud.opts['cloudseed'].get('ip_address', None), 'private_ips': cloud.opts['cloudseed'].get('private_ip_address', None) } target_ip = interface_ips.get(ssh_interface, None) if not target_ip: # TODO Better, more informative error please. raise RuntimeError saltcloud_conf['minion'] = { 'master': target_ip} saltcloud_obj = writers.write_stringio( yaml.safe_dump(saltcloud_conf, default_flow_style=False)) manifest.add(saltcloud_obj, '/etc/salt/cloud')
def sync_full_manifest(manifest): cloud = cloudseed.cloud.Cloud(__opts__) vm_ = cloud.vm_profile('master') keyname = '%s-%s' % (env.location_name(), env.env_name()) filename = os.path.join( env.current_env_path(), 'salt', '%s.pem' % keyname) manifest.add(filename, '/etc/salt/cloud.pem') # changing the path to the private_key file to work on # the bootstrapped master providers = filesystem.read_file(__opts__['providers_config']) providers_data = yaml.load(providers) alias, driver = vm_['provider'].split(':') master_provider = providers_data[alias] master_provider['private_key'] = '/etc/salt/cloud.pem' cloud_providers = yaml.safe_dump(providers_data, default_flow_style=False) manifest.remove('cloudseed/current/salt/cloud.providers') manifest.add( writers.write_stringio(cloud_providers), '/etc/salt/cloud.providers')
def _add_saltcloud_conf(manifest, cloud): saltcloud_conf = yaml.load( filesystem.read_file('cloudseed/current/salt/cloud')) if not saltcloud_conf: saltcloud_conf = {} ssh_interface = cloud.opts.get('ssh_interface', 'private_ips') interface_ips = { 'public_ips': cloud.opts['cloudseed'].get('ip_address', None), 'private_ips': cloud.opts['cloudseed'].get('private_ip_address', None) } target_ip = interface_ips.get(ssh_interface, None) if not target_ip: # TODO Better, more informative error please. raise RuntimeError saltcloud_conf['minion'] = {'master': target_ip} saltcloud_obj = writers.write_stringio( yaml.safe_dump(saltcloud_conf, default_flow_style=False)) manifest.add(saltcloud_obj, '/etc/salt/cloud')
def sync_full_manifest(manifest): cloud = cloudseed.cloud.Cloud(__opts__) vm_ = cloud.vm_profile('master') keyname = '%s-%s' % (env.location_name(), env.env_name()) filename = os.path.join(env.current_env_path(), 'salt', '%s.pem' % keyname) manifest.add(filename, '/etc/salt/cloud.pem') # changing the path to the private_key file to work on # the bootstrapped master providers = filesystem.read_file(__opts__['providers_config']) providers_data = yaml.load(providers) alias, driver = vm_['provider'].split(':') master_provider = providers_data[alias] master_provider['private_key'] = '/etc/salt/cloud.pem' cloud_providers = yaml.safe_dump(providers_data, default_flow_style=False) manifest.remove('cloudseed/current/salt/cloud.providers') manifest.add(writers.write_stringio(cloud_providers), '/etc/salt/cloud.providers')
def create_master(vm_=None, call=None): # always assumes we are running locally, creating a # master for the 1st time cloud = cloudseed.cloud.Cloud(__opts__) bootstrap_master(vm_, cloud) master = filesystem.read_file(__opts__['master_config']) vm_['cloudseed'] = { 'master': master } data = saltcloud_ec2_create(vm_) log.debug('VM: %s', vm_) log.debug('VM Created: %s', data) if 'Errors' in data: message = data['Errors']['Error']['Message'] log.error('%s', message) return conf = { 'ip_address': data['ipAddress'], 'dns_name': data['dnsName'], 'private_ip_address': data['privateIpAddress'], 'instance_id': data['instanceId'], 'profile': vm_.get('profile', None), 'name': vm_['name'], } conf_filename = os.path.join(env.current_env_path(), 'salt', 'cloudseed') with open(conf_filename, 'w') as f: f.write(yaml.safe_dump(conf, default_flow_style=False)) sync.sync_full() salt.master_salt_call_highstate() event = { 'fun': 'create.master', 'return': conf } # assumes being run locally cloudseed.agent.commands.fire_event(event) return data
def create_master(vm_=None, call=None): # always assumes we are running locally, creating a # master for the 1st time cloud = cloudseed.cloud.Cloud(__opts__) bootstrap_master(vm_, cloud) master = filesystem.read_file(__opts__['master_config']) vm_['cloudseed'] = {'master': master} data = saltcloud_ec2_create(vm_) log.debug('VM: %s', vm_) log.debug('VM Created: %s', data) if 'Errors' in data: message = data['Errors']['Error']['Message'] log.error('%s', message) return conf = { 'ip_address': data['ipAddress'], 'dns_name': data['dnsName'], 'private_ip_address': data['privateIpAddress'], 'instance_id': data['instanceId'], 'profile': vm_.get('profile', None), 'name': vm_['name'], } conf_filename = os.path.join(env.current_env_path(), 'salt', 'cloudseed') with open(conf_filename, 'w') as f: f.write(yaml.safe_dump(conf, default_flow_style=False)) sync.sync_full() salt.master_salt_call_highstate() event = {'fun': 'create.master', 'return': conf} # assumes being run locally cloudseed.agent.commands.fire_event(event) return data
def bootstrap_master(vm_, cloud): provider = cloud.provider_profile_full(vm_) provider['ssh_interface'] = 'public_ips' append_data = {} if not provider.get('keyname', False): keyname = '%s-%s' % (env.location_name(), env.env_name()) filename = os.path.join( env.current_env_path(), 'salt', '%s.pem' % keyname) bootstrap_create_keypair(keyname, filename) # set it for the current command provider['keyname'] = keyname provider['private_key'] = filename append_data['keyname'] = keyname append_data['private_key'] = 'cloudseed/current/salt/%s.pem' % keyname else: if not os.path.isabs(provider['private_key']): new_path = os.path.abspath(provider['private_key']) provider['private_key'] = new_path groups = bootstrap_master_security_groups(vm_, provider) append_data['securitygroup'] = groups # write down and new data if append_data: provider_bytes = filesystem.read_file(cloud.opts['providers_config']) provider_data = yaml.load(provider_bytes) alias, driver = vm_['provider'].split(':') target = provider_data[alias] target.update(append_data) writers.write_yaml(cloud.opts['providers_config'], provider_data)
def bootstrap_master(vm_, cloud): provider = cloud.provider_profile_full(vm_) provider['ssh_interface'] = 'public_ips' append_data = {} if not provider.get('keyname', False): keyname = '%s-%s' % (env.location_name(), env.env_name()) filename = os.path.join(env.current_env_path(), 'salt', '%s.pem' % keyname) bootstrap_create_keypair(keyname, filename) # set it for the current command provider['keyname'] = keyname provider['private_key'] = filename append_data['keyname'] = keyname append_data['private_key'] = 'cloudseed/current/salt/%s.pem' % keyname else: if not os.path.isabs(provider['private_key']): new_path = os.path.abspath(provider['private_key']) provider['private_key'] = new_path groups = bootstrap_master_security_groups(vm_, provider) append_data['securitygroup'] = groups # write down and new data if append_data: provider_bytes = filesystem.read_file(cloud.opts['providers_config']) provider_data = yaml.load(provider_bytes) alias, driver = vm_['provider'].split(':') target = provider_data[alias] target.update(append_data) writers.write_yaml(cloud.opts['providers_config'], provider_data)