mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
hpilo_boot: Boot/power via HP iLO mgmt board (#21674)
This is the original `hpilo_boot` module that was once accepted in Ansible but had been removed subsequently because it could not be tested by the Ansible project. Since then it was moved to the ansible-provisioning project and maintained by HP engineers going forward. Now we are trying to get it upstreamed again.
This commit is contained in:
parent
43b8debf9b
commit
c9c8be6459
2 changed files with 223 additions and 11 deletions
26
CHANGELOG.md
26
CHANGELOG.md
|
@ -63,7 +63,7 @@ Ansible Changes By Release
|
||||||
|
|
||||||
###New Modules:
|
###New Modules:
|
||||||
- a10_server_axapi3
|
- a10_server_axapi3
|
||||||
- amazon
|
- amazon:
|
||||||
* aws_kms
|
* aws_kms
|
||||||
* cloudfront_facts
|
* cloudfront_facts
|
||||||
* ec2_group_facts
|
* ec2_group_facts
|
||||||
|
@ -81,10 +81,10 @@ Ansible Changes By Release
|
||||||
- bigswitch:
|
- bigswitch:
|
||||||
* bigmon_chain
|
* bigmon_chain
|
||||||
* bigmon_policy
|
* bigmon_policy
|
||||||
- cloudengine
|
- cloudengine:
|
||||||
* ce_command
|
* ce_command
|
||||||
- cloudscale_server
|
- cloudscale_server
|
||||||
- cloudstack
|
- cloudstack:
|
||||||
* cs_host
|
* cs_host
|
||||||
* cs_nic
|
* cs_nic
|
||||||
* cs_region
|
* cs_region
|
||||||
|
@ -95,7 +95,7 @@ Ansible Changes By Release
|
||||||
* eos_banner
|
* eos_banner
|
||||||
* eos_system
|
* eos_system
|
||||||
* eos_user
|
* eos_user
|
||||||
- f5
|
- f5:
|
||||||
* bigip_gtm_facts
|
* bigip_gtm_facts
|
||||||
* bigip_hostname
|
* bigip_hostname
|
||||||
* bigip_snat_pool
|
* bigip_snat_pool
|
||||||
|
@ -106,11 +106,15 @@ Ansible Changes By Release
|
||||||
- fortios
|
- fortios
|
||||||
* fortios_config
|
* fortios_config
|
||||||
- gconftool2
|
- gconftool2
|
||||||
- google
|
- google:
|
||||||
* gce_eip
|
* gce_eip
|
||||||
* gce_snapshot
|
* gce_snapshot
|
||||||
* gcpubsub
|
* gcpubsub
|
||||||
* gcpubsub_facts
|
* gcpubsub_facts
|
||||||
|
- hpilo:
|
||||||
|
* hpilo_boot
|
||||||
|
* hpilo_facts
|
||||||
|
* hponcfg
|
||||||
- icinga2_feature
|
- icinga2_feature
|
||||||
- illumos:
|
- illumos:
|
||||||
* dladm_iptun
|
* dladm_iptun
|
||||||
|
@ -126,7 +130,7 @@ Ansible Changes By Release
|
||||||
* infini_host
|
* infini_host
|
||||||
* infini_pool
|
* infini_pool
|
||||||
* infini_vol
|
* infini_vol
|
||||||
- ipa
|
- ipa:
|
||||||
* ipa_group
|
* ipa_group
|
||||||
* ipa_hbacrule
|
* ipa_hbacrule
|
||||||
* ipa_host
|
* ipa_host
|
||||||
|
@ -148,7 +152,7 @@ Ansible Changes By Release
|
||||||
- logstash_plugin
|
- logstash_plugin
|
||||||
- mattermost
|
- mattermost
|
||||||
- net_command
|
- net_command
|
||||||
- netapp
|
- netapp:
|
||||||
* sf_account_manager
|
* sf_account_manager
|
||||||
* sf_snapshot_schedule_manager
|
* sf_snapshot_schedule_manager
|
||||||
* sf_volume_manager
|
* sf_volume_manager
|
||||||
|
@ -159,11 +163,11 @@ Ansible Changes By Release
|
||||||
- openssl:
|
- openssl:
|
||||||
* openssl_privatekey
|
* openssl_privatekey
|
||||||
* openssl_publickey
|
* openssl_publickey
|
||||||
- openstack
|
- openstack:
|
||||||
* os_nova_host_aggregate
|
* os_nova_host_aggregate
|
||||||
* os_quota
|
* os_quota
|
||||||
- openwrt_init
|
- openwrt_init
|
||||||
- ordnance
|
- ordnance:
|
||||||
* ordnance_config
|
* ordnance_config
|
||||||
* ordnance_facts
|
* ordnance_facts
|
||||||
- ovirt:
|
- ovirt:
|
||||||
|
@ -237,7 +241,7 @@ Ansible Changes By Release
|
||||||
- stacki_host
|
- stacki_host
|
||||||
- swupd
|
- swupd
|
||||||
- tempfile
|
- tempfile
|
||||||
- tower
|
- tower:
|
||||||
* tower_credential
|
* tower_credential
|
||||||
* tower_group
|
* tower_group
|
||||||
* tower_host
|
* tower_host
|
||||||
|
@ -252,7 +256,7 @@ Ansible Changes By Release
|
||||||
- vmware:
|
- vmware:
|
||||||
* vmware_guest_facts
|
* vmware_guest_facts
|
||||||
* vmware_guest_snapshot
|
* vmware_guest_snapshot
|
||||||
- web_infrastructure
|
- web_infrastructure:
|
||||||
* jenkins_script
|
* jenkins_script
|
||||||
- windows:
|
- windows:
|
||||||
* win_dns_client
|
* win_dns_client
|
||||||
|
|
208
lib/ansible/modules/remote_management/hpilo/hpilo_boot.py
Executable file
208
lib/ansible/modules/remote_management/hpilo/hpilo_boot.py
Executable file
|
@ -0,0 +1,208 @@
|
||||||
|
#!/usr/bin/python
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
|
||||||
|
# Copyright 2012 Dag Wieers <dag@wieers.com>
|
||||||
|
#
|
||||||
|
# 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 <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
ANSIBLE_METADATA = {'status': ['preview'],
|
||||||
|
'supported_by': 'community',
|
||||||
|
'version': '1.0'}
|
||||||
|
|
||||||
|
DOCUMENTATION = '''
|
||||||
|
---
|
||||||
|
module: hpilo_boot
|
||||||
|
version_added: "2.3"
|
||||||
|
author: Dag Wieers (@dagwieers)
|
||||||
|
short_description: Boot system using specific media through HP iLO interface
|
||||||
|
description:
|
||||||
|
- "This module boots a system through its HP iLO interface. The boot media
|
||||||
|
can be one of: cdrom, floppy, hdd, network or usb."
|
||||||
|
- This module requires the hpilo python module.
|
||||||
|
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.
|
||||||
|
default: Administrator
|
||||||
|
password:
|
||||||
|
description:
|
||||||
|
- The password to authenticate to the HP iLO interface.
|
||||||
|
default: admin
|
||||||
|
media:
|
||||||
|
description:
|
||||||
|
- The boot media to boot the system from
|
||||||
|
default: network
|
||||||
|
choices: [ "cdrom", "floppy", "hdd", "network", "normal", "usb" ]
|
||||||
|
image:
|
||||||
|
description:
|
||||||
|
- The URL of a cdrom, floppy or usb boot media image.
|
||||||
|
protocol://username:password@hostname:port/filename
|
||||||
|
- protocol is either 'http' or 'https'
|
||||||
|
- username:password is optional
|
||||||
|
- port is optional
|
||||||
|
state:
|
||||||
|
description:
|
||||||
|
- The state of the boot media.
|
||||||
|
- "no_boot: Do not boot from the device"
|
||||||
|
- "boot_once: Boot from the device once and then notthereafter"
|
||||||
|
- "boot_always: Boot from the device each time the serveris rebooted"
|
||||||
|
- "connect: Connect the virtual media device and set to boot_always"
|
||||||
|
- "disconnect: Disconnects the virtual media device and set to no_boot"
|
||||||
|
- "poweroff: Power off the server"
|
||||||
|
default: boot_once
|
||||||
|
choices: [ "boot_always", "boot_once", "connect", "disconnect", "no_boot", "poweroff" ]
|
||||||
|
force:
|
||||||
|
description:
|
||||||
|
- Whether to force a reboot (even when the system is already booted).
|
||||||
|
- As a safeguard, without force, hpilo_boot will refuse to reboot a server that is already running.
|
||||||
|
default: no
|
||||||
|
choices: [ "yes", "no" ]
|
||||||
|
requirements:
|
||||||
|
- hpilo
|
||||||
|
notes:
|
||||||
|
- To use a USB key image you need to specify floppy as boot media.
|
||||||
|
- This module ought to be run from a system that can access the HP iLO
|
||||||
|
interface directly, either by using C(local_action) or using C(delegate_to).
|
||||||
|
'''
|
||||||
|
|
||||||
|
EXAMPLES = r'''
|
||||||
|
- name: Task to boot a system using an ISO from an HP iLO interface only if the system is an HP server
|
||||||
|
hpilo_boot:
|
||||||
|
host: YOUR_ILO_ADDRESS
|
||||||
|
login: YOUR_ILO_LOGIN
|
||||||
|
password: YOUR_ILO_PASSWORD
|
||||||
|
media: cdrom
|
||||||
|
image: http://some-web-server/iso/boot.iso
|
||||||
|
when: cmdb_hwmodel.startswith('HP ')
|
||||||
|
delegate_to: localhost
|
||||||
|
|
||||||
|
- name: Power off a server
|
||||||
|
hpilo_boot:
|
||||||
|
host: YOUR_ILO_HOST
|
||||||
|
login: YOUR_ILO_LOGIN
|
||||||
|
password: YOUR_ILO_PASSWORD
|
||||||
|
state: poweroff
|
||||||
|
delegate_to: localhost
|
||||||
|
'''
|
||||||
|
|
||||||
|
RETURN = '''
|
||||||
|
# Default return values
|
||||||
|
'''
|
||||||
|
|
||||||
|
|
||||||
|
import time
|
||||||
|
import warnings
|
||||||
|
from ansible.module_utils.basic import AnsibleModule
|
||||||
|
|
||||||
|
try:
|
||||||
|
import hpilo
|
||||||
|
HAS_HPILO = True
|
||||||
|
except ImportError:
|
||||||
|
HAS_HPILO = False
|
||||||
|
|
||||||
|
|
||||||
|
# Suppress warnings from hpilo
|
||||||
|
warnings.simplefilter('ignore')
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
|
||||||
|
module = AnsibleModule(
|
||||||
|
argument_spec = dict(
|
||||||
|
host = dict(required=True, type='str'),
|
||||||
|
login = dict(default='Administrator', type='str'),
|
||||||
|
password = dict(default='admin', type='str', no_log=True),
|
||||||
|
media = dict(default=None, type='str', choices=['cdrom', 'floppy', 'rbsu', 'hdd', 'network', 'normal', 'usb']),
|
||||||
|
image = dict(default=None, type='str'),
|
||||||
|
state = dict(default='boot_once', type='str', choices=['boot_always', 'boot_once', 'connect', 'disconnect', 'no_boot', 'poweroff']),
|
||||||
|
force = dict(default=False, type='bool'),
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
if not HAS_HPILO:
|
||||||
|
module.fail_json(msg='The hpilo python module is required')
|
||||||
|
|
||||||
|
host = module.params['host']
|
||||||
|
login = module.params['login']
|
||||||
|
password = module.params['password']
|
||||||
|
media = module.params['media']
|
||||||
|
image = module.params['image']
|
||||||
|
state = module.params['state']
|
||||||
|
force = module.params['force']
|
||||||
|
|
||||||
|
ilo = hpilo.Ilo(host, login=login, password=password)
|
||||||
|
changed = False
|
||||||
|
status = {}
|
||||||
|
power_status = 'UNKNOWN'
|
||||||
|
|
||||||
|
if media and state in ('boot_always', 'boot_once', 'connect', 'disconnect', 'no_boot'):
|
||||||
|
|
||||||
|
# Workaround for: Error communicating with iLO: Problem manipulating EV
|
||||||
|
try:
|
||||||
|
ilo.set_one_time_boot(media)
|
||||||
|
except hpilo.IloError:
|
||||||
|
time.sleep(60)
|
||||||
|
ilo.set_one_time_boot(media)
|
||||||
|
|
||||||
|
# TODO: Verify if image URL exists/works
|
||||||
|
if image:
|
||||||
|
ilo.insert_virtual_media(media, image)
|
||||||
|
changed = True
|
||||||
|
|
||||||
|
if media == 'cdrom':
|
||||||
|
ilo.set_vm_status('cdrom', state, True)
|
||||||
|
status = ilo.get_vm_status()
|
||||||
|
changed = True
|
||||||
|
elif media in ('floppy', 'usb'):
|
||||||
|
ilo.set_vf_status(state, True)
|
||||||
|
status = ilo.get_vf_status()
|
||||||
|
changed = True
|
||||||
|
|
||||||
|
# Only perform a boot when state is boot_once or boot_always, or in case we want to force a reboot
|
||||||
|
if state in ('boot_once', 'boot_always') or force:
|
||||||
|
|
||||||
|
power_status = ilo.get_host_power_status()
|
||||||
|
|
||||||
|
if not force and power_status == 'ON':
|
||||||
|
module.fail_json(msg='HP iLO (%s) reports that the server is already powered on !' % host)
|
||||||
|
|
||||||
|
if power_status == 'ON':
|
||||||
|
#ilo.cold_boot_server()
|
||||||
|
ilo.warm_boot_server()
|
||||||
|
changed = True
|
||||||
|
else:
|
||||||
|
ilo.press_pwr_btn()
|
||||||
|
#ilo.reset_server()
|
||||||
|
#ilo.set_host_power(host_power=True)
|
||||||
|
changed = True
|
||||||
|
|
||||||
|
elif state in ('poweroff'):
|
||||||
|
|
||||||
|
power_status = ilo.get_host_power_status()
|
||||||
|
|
||||||
|
if not power_status == 'OFF':
|
||||||
|
ilo.hold_pwr_btn()
|
||||||
|
#ilo.set_host_power(host_power=False)
|
||||||
|
changed = True
|
||||||
|
|
||||||
|
module.exit_json(changed=changed, power=power_status, **status)
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
Loading…
Add table
Reference in a new issue