Пример #1
0
def action_list():
    ksclient = Keystone(options.config, debug=options.debug, log=logger)
    status = 'deactivated' if options.deactive else 'active'
    filters = {'status': status, 'visibility': options.visibility, 'tag': tags}
    logger.debug('=> filter: %s' % filters)
    images = glclient.get_images(filters=filters)
    out_image = {'header': 'Image list (id, name, created_at)'}
    if options.format == 'text':
        printer.output_dict(out_image)
    count = 0
    for image in images:
        out_image = {
            'name': image.name,
            'created': image.created_at,
            'id': image.id
        }
        if options.detailed and image.visibility == 'private':
            access = glclient.get_access(image.id)
            if access:
                access_list = list()
                for member in access:
                    project = ksclient.get_by_id('project',
                                                 member['member_id'])
                    if project:
                        access_list.append(project.name)
                out_image['projects'] = access_list
        if options.detailed and hasattr(image, 'depricated'):
            out_image['depricated'] = image.depricated
        if options.detailed:
            out_image['tags'] = image.tags
        one_line = False if options.detailed else True
        printer.output_dict(out_image, sort=True, one_line=one_line)
        count += 1
    out_image = {'header': 'Image count', 'count': count}
    printer.output_dict(out_image)
Пример #2
0
def action_grant():
    ksclient = Keystone(options.config, debug=options.debug, log=logger)
    project = ksclient.get_project(project=options.project,
                                   domain=options.domain)
    if not project:
        himutils.sys_error('Unknown project %s in domain %s' %
                           (options.project, options.domain))
    if options.name:
        tags.append(options.name)
    filters = {'status': 'active', 'tag': tags, 'visibility': 'private'}
    logger.debug('=> filter: %s' % filters)
    images = glclient.get_images(filters=filters)
    for image in images:
        log_msg = 'grant access to %s from %s' % (image.name, project.name)
        if not options.dry_run:
            glclient.set_access(image.id, project.id)
        else:
            log_msg = 'DRY-RUN: %s' % log_msg
        logger.debug('=> %s' % log_msg)
Пример #3
0
def process_action(ch, method, properties, body): #callback
    ch.basic_ack(delivery_tag=method.delivery_tag)

    logger = logging.getLogger(sname)
    kc = Keystone(config_path=himlarcli_config, debug=options.debug, log=logger)
    kc.set_domain('dataporten')

    data = json.loads(body)
    user = kc.get_user_by_email(data['email'], user_type='api')

    logger.info('processing %s for %s', data['action'], data['email'])

    if user:
        if data['action'] == 'reset_password':
            reset = kc.reset_password(email=data['email'], password=data['password'])
        elif data['action'] == 'provision':
            logger.info('user exists! %s', data['email'])
    else:
        if data['action'] == 'provision':
            provision = kc.provision_dataporten(email=data['email'], password=data['password'])
        elif data['action'] == 'reset_password':
            logger.info('Provisioning is required! %s', data['email'])
Пример #4
0
from himlarcli.keystone import Keystone
from himlarcli.cinder import Cinder
from himlarcli.nova import Nova
from himlarcli.neutron import Neutron
from himlarcli.parser import Parser
from himlarcli.printer import Printer
from himlarcli import utils as himutils

himutils.is_virtual_env()

parser = Parser()
options = parser.parse_args()
printer = Printer(options.format)

ksclient = Keystone(options.config, debug=options.debug)
logger = ksclient.get_logger()
regions = ksclient.find_regions(region_name=options.region)

if not regions:
    himutils.sys_error('no regions found!')


def action_show():
    for region in regions:
        novaclient = Nova(options.config,
                          debug=options.debug,
                          log=logger,
                          region=region)
        cinderclient = Cinder(options.config,
                              debug=options.debug,
Пример #5
0
from sqlalchemy import create_engine
from sqlalchemy.orm import sessionmaker
from datetime import datetime

from himlarcli.keystone import Keystone
from himlarcli.nova import Nova
from himlarcli.neutron import Neutron
from himlarcli.parser import Parser
from himlarcli import utils as himutils

parser = Parser()
parser.toggle_show('dry-run')
parser.toggle_show('format')
options = parser.parse_args()

kc= Keystone(options.config, debug=options.debug)
kc.set_domain(options.domain)
logger = kc.get_logger()

# Region
if hasattr(options, 'region'):
    regions = kc.find_regions(region_name=options.region)
else:
    regions = kc.find_regions()

logger.debug('=> regions used: %s', ','.join(regions))

Base = declarative_base()

class Owner(Base):
    __tablename__ = 'owners'
Пример #6
0
    def prettyprint_project_instances(project, options, logger, regions):
        out_str = ''
        instances_total = 0
        instances = dict()

        # Get Instances
        for region in regions:
            # Initiate Nova object
            nc = utils.get_client(Nova, options, logger, region)

            # Get a list of instances in project
            instances[region] = nc.get_project_instances(project_id=project.id)
            for instance in instances[region]:
                instances_total += 1

        # Print Instances table
        if instances_total > 0:
            kc = Keystone(options.config, debug=options.debug)
            kc.set_dry_run(options.dry_run)
            kc.set_domain(options.domain)

            table_instances = PrettyTable()
            table_instances.field_names = [
                'id', 'name', 'status', 'owner', 'IPv4', 'IPv6', 'region',
                'flavor', 'image [status]'
            ]
            table_instances.align['id'] = 'l'
            table_instances.align['name'] = 'l'
            table_instances.align['status'] = 'l'
            table_instances.align['owner'] = 'l'
            table_instances.align['IPv4'] = 'l'
            table_instances.align['IPv6'] = 'l'
            table_instances.align['region'] = 'l'
            table_instances.align['flavor'] = 'l'
            table_instances.align['image [status]'] = 'l'
            for region in regions:
                # Initiate Glance object
                gc = utils.get_client(Glance, options, logger, region)
                for instance in instances[region]:
                    if len(instance.addresses.keys()) > 0:
                        network = instance.addresses.keys()[0]
                        ipv4_list = []
                        ipv6_list = []
                        for interface in instance.addresses[network]:
                            if interface['version'] == 4:
                                ipv4_list.append(interface['addr'])
                            if interface['version'] == 6:
                                ipv6_list.append(interface['addr'])
                        ipv4_addresses = ", ".join(ipv4_list)
                        ipv6_addresses = ", ".join(ipv6_list)
                    else:
                        ipv4_addresses = 'None'
                        ipv6_addresses = 'None'
                    if 'id' not in instance.image:
                        image_name = 'UNKNOWN'
                        image_status = 'N/A'
                    else:
                        filters = {'id': instance.image['id']}
                        image = gc.find_image(filters=filters, limit=1)
                        if len(image) == 1:
                            image_name = image[0]['name']
                            image_status = image[0]['status']
                        else:
                            image_name = 'UNKNOWN'
                            image_status = 'N/A'
                    user = kc.get_by_id('user', instance.user_id)
                    owner = user.name if user else '(deleted-user)'
                    row = []
                    row.append(instance.id)
                    row.append(instance.name)
                    row.append(instance.status)
                    row.append(owner)
                    row.append(ipv4_addresses)
                    row.append(ipv6_addresses)
                    row.append(region)
                    row.append(instance.flavor["original_name"])
                    row.append("%s [%s]" % (image_name, image_status))
                    table_instances.add_row(row)
            out_str += "\n  Instances (%d): \n" % instances_total
            out_str += table_instances.get_string() + "\n"

        return out_str.encode('utf-8')
Пример #7
0
    def prettyprint_project_metadata(project,
                                     options,
                                     logger,
                                     regions,
                                     user=None):
        out_str = ''
        kc = Keystone(options.config, debug=options.debug)
        kc.set_dry_run(options.dry_run)
        kc.set_domain(options.domain)

        project_type = project.type if hasattr(project,
                                               'type') else '(unknown)'
        project_admin = project.admin if hasattr(project,
                                                 'admin') else '(unknown)'
        project_created = project.createdate if hasattr(
            project, 'createdate') else '(unknown)'
        project_enddate = project.enddate if hasattr(project,
                                                     'enddate') else 'None'
        project_contact = project.contact if hasattr(project,
                                                     'contact') else 'None'
        project_roles = kc.list_roles(project_name=project.name)

        # Make project create date readable
        project_created = re.sub(r'T\d\d:\d\d:\d\d.\d\d\d\d\d\d', '',
                                 project_created)

        # Disabled project?
        status = "*** DISABLED *** " if not project.enabled else ''

        # Print header for project
        out_str += "%sPROJECT: %s" % (status, project.name)
        if user is not None and not options.admin:
            prole = 'admin' if user == project.admin else 'member'
            out_str += " (%s)" % prole
        out_str += "\n" + '=' * 80 + "\n"

        # Print project metadata
        table_metadata = PrettyTable()
        table_metadata._max_width = {'value': 70}
        table_metadata.border = 0
        table_metadata.header = 0
        table_metadata.field_names = ['meta', 'value']
        table_metadata.align['meta'] = 'r'
        table_metadata.align['value'] = 'l'
        table_metadata.add_row(['ID:', project.id])
        table_metadata.add_row(['Admin:', project_admin])
        table_metadata.add_row(['Contact:', project_contact])
        table_metadata.add_row(['Type:', project_type])
        table_metadata.add_row(['Created:', project_created])
        table_metadata.add_row(['Enddate:', project_enddate])
        table_metadata.add_row(['Description:', project.description])
        if len(project_roles) > 0:
            users = dict()
            users['user'] = []
            users['object'] = []
            users['superuser'] = []
            for role in project_roles:
                user = role['group'].replace('-group', '')
                users[role['role']].append(user)
            table_metadata.add_row(['Users:', "\n".join(users['user'])])
            if len(users['superuser']) > 0:
                table_metadata.add_row(
                    ['Superusers:', "\n".join(users['superuser'])])
            if len(users['object']) > 0:
                table_metadata.add_row(
                    ['Object Users:', "\n".join(users['object'])])
        if not options.detail:
            zones = Printer._count_project_zones(project, options, logger)
            volumes = Printer._count_project_volumes(project, options, logger,
                                                     regions)
            images = Printer._count_project_images(project, options, logger,
                                                   regions)
            instances = Printer._count_project_instances(
                project, options, logger, regions)
            volume_list = []
            image_list = []
            instance_list = []
            for region in regions:
                volume_list.append("%d (%s)" % (volumes[region], region))
                image_list.append("%d (%s)" % (images[region], region))
                instance_list.append("%d (%s)" % (instances[region], region))
            table_metadata.add_row(['Zones:', zones])
            table_metadata.add_row(['Volumes:', ', '.join(volume_list)])
            table_metadata.add_row(['Images:', ', '.join(image_list)])
            table_metadata.add_row(['Instances:', ', '.join(instance_list)])

        out_str += table_metadata.get_string() + "\n"
        return out_str.encode('utf-8')
Пример #8
0
#!/usr/bin/env python

import sys
import pprint
import utils
import statsd
from himlarcli import utils as himutils
from himlarcli.nova import Nova
from himlarcli.keystone import Keystone

options = utils.get_options('Print openstack location stats', hosts=False)

# Project
keystoneclient = Keystone(options.config, options.debug)
projects_count = keystoneclient.get_project_count('dataporten')
users_count = keystoneclient.get_user_count('dataporten')
logger = keystoneclient.get_logger()

stats = dict()
stats['projects'] = {}
stats['instances'] = {}
stats['instances']['total'] = {'count': 0, 'error': 0}
stats['users'] = {}
stats['projects'][keystoneclient.region] = {}
stats['projects'][keystoneclient.region]['count'] = projects_count
stats['users'][keystoneclient.region] = {}
stats['users'][keystoneclient.region]['count'] = users_count

server = keystoneclient.get_config('statsd', 'server')
port = keystoneclient.get_config('statsd', 'port')