示例#1
0
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')
示例#2
0
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')
示例#3
0
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')
示例#4
0
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')
示例#5
0
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
示例#6
0
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
示例#7
0
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)
示例#8
0
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)