#!/usr/bin/python # -*- coding: utf-8 -*- # Copyright 2012 Dag Wieers # # This file is part of Ansible # # Ansible is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # Ansible is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with Ansible. If not, see . DOCUMENTATION = ''' --- author: Dag Wieers module: hpilo_facts short_description: Gather facts for a systel through HP iLO interface description: - This module gathers facts for a specific system using its HP iLO interface. These facts include hardware and network related information useful for provisioning (e.g. macaddress, uuid). - This module requires the hpilo python module. version_added: "0.8" options: host: description: - The HP iLO hostname/address that is linked to the physical system. required: true login: description: - The login name to authenticate to the HP iLO interface. required: false default: Administrator password: description: - The password to authenticate to the HP iLO interface. required: false default: admin match: description: - An optional string to match against the iLO server name. - This is a safety measure to prevent accidentally using the wrong HP iLO interface with dire consequences. required: false examples: - code: | local_action: hpilo_facts host=$ilo_address login=$ilo_login password=$ilo_password match=$inventory_hostname_short only_if: "'$cmdb_hwmodel'.startswith('HP ') description: Task to gather facts from a HP iLO interface only if the system is an HP server - description: Typical output of HP iLO_facts for a physical system code: | - hw_bios_date: "05/05/2011" hw_bios_version: "P68" hw_eth0: - macaddress: "00:11:22:33:44:55" macaddress_dash: "00-11-22-33-44-55" hw_eth1: - macaddress: "00:11:22:33:44:57" macaddress_dash: "00-11-22-33-44-57" hw_eth2: - macaddress: "00:11:22:33:44:5A" macaddress_dash: "00-11-22-33-44-5A" hw_eth3: - macaddress: "00:11:22:33:44:5C" macaddress_dash: "00-11-22-33-44-5C" hw_eth_ilo: - macaddress: "00:11:22:33:44:BA" macaddress_dash: "00-11-22-33-44-BA" hw_product_name: "ProLiant DL360 G7" hw_product_uuid: "ef50bac8-2845-40ff-81d9-675315501dac" hw_system_serial: "ABC12345D6" hw_uuid: "123456ABC78901D2" notes: - This module ought to be run from a system that can access the HP iLO interface directly, either by using C(local_action) or C(using delegate)_to. ''' import sys import warnings try: import hpilo except ImportError: print "failed=True msg='hpilo python module unavailable'" sys.exit(1) ### Surpress warnings from hpilo warnings.simplefilter('ignore') def main(): module = AnsibleModule( argument_spec=dict( host = dict(required=True), login = dict(default='Administrator'), password = dict(default='admin'), match = dict(default=None), ) ) host = module.params['host'] login = module.params['login'] password = module.params['password'] ilo = hpilo.Ilo(host, login=login, password=password) # If match=string is provided, only reboot server if iLO name matches 'string' if module.params['match'] != None: try: server_name = ilo.get_server_name() except Exception, e: module.fail_json(rc=1, msg='Failed to connect to %s: %s' % (host, e.message)) if not server_name.lower().startswith(module.params['match'].lower()): module.fail_json(rc=1, msg='The iLO server name \'%s\' does not match \'%s\'' % (server_name, module.params['match'])) # TODO: Count number of CPUs, DIMMs and total memory data = ilo.get_host_data() facts = {} for entry in data: if not entry.has_key('type'): continue if entry['type'] == 0: # BIOS Information facts['hw_bios_version'] = entry['Family'] facts['hw_bios_date'] = entry['Date'] elif entry['type'] == 1: # System Information facts['hw_uuid'] = entry['UUID'] facts['hw_system_serial'] = entry['Serial Number'] facts['hw_product_name'] = entry['Product Name'] facts['hw_product_uuid'] = entry['cUUID'] elif entry['type'] == 209: # Embedded NIC MAC Assignment for (name, value) in [ (e['name'], e['value']) for e in entry['fields'] ]: if name.startswith('Port'): try: factname = 'hw_eth' + str(int(value) - 1) except: factname = 'hw_eth_ilo' elif name.startswith('MAC'): facts[factname] = { 'macaddress': value.replace('-', ':'), 'macaddress_dash': value } elif entry['type'] == 209: # HPQ NIC iSCSI MAC Info for (name, value) in [ (e['name'], e['value']) for e in entry['fields'] ]: if name.startswith('Port'): try: factname = 'hw_iscsi' + str(int(value) - 1) except: factname = 'hw_iscsi_ilo' elif name.startswith('MAC'): facts[factname] = { 'macaddress': value.replace('-', ':'), 'macaddress_dash': value } module.exit_json(ansible_facts=facts) # this is magic, see lib/ansible/module_common.py #<> main()