The module provides resources to spawn a command on a PTY and to interact with it from Puppet DSL.
Use pty::spawn()
function in a Bolt plan to spawn a command on a newly
allocated PTY. In a block form, this function yields a PTY::IO object as a
block parameter. When the function has no block, it'll return a PTY::IO object.
Use the PTY::IO object to interact with the process spawned.
$pty = pty::spawn(['/bin/sh', '--norc'])
# Enable debug messages on stderr
$pty.set_debug(true)
# Switch PTY to raw mode
$pty.set_raw()
# Change PS1 prompt to something we know
$pty.puts('export PS1="pty::io$ "')
# Read reply and throw it away (wait 0.5 second for more input if any)
$pty.read(timeout => 0.5)
# Set the prompt to be expected by `pwp()` and `pwp_until()` methods
$pty.set_expected_prompt(/\Rpty::io\$ /)
# Send `hostname` command, get reply and strip any whitespace including
# terminating '\n'
$hostname = $pty.pwp('hostname').strip()
out::verbose($hostname)
# Type '# Hello world'
out::verbose($pty.type_in('# Hello world'))
# Print current unix time and check if last digit is 0. Repeat 11 times if
# not, waiting 1 sec before next iteration. Return unix time matching.
$time = $pty.pwp_until('date +"%s"', /0$/, { interval => 1, limit => 11 }).strip()
out::verbose($time)
# Close IO streams and kill the process
$pty.close()
WARNING: Do not execute this code in your environment until you clearly understand what it does. The module authors takes no responsibility for any damage, loss, or injury resulting from the use or inability to use this example code. By using this example code, you acknowledge that you do so at your own risk!
$targets.get_targets.parallelize |$t| {
pty::spawn(['/usr/bin/ssh', $t.vars.get('bmc_host')]) |$bmc| {
$bmc.set_raw()
$bmc.expect(/^(\/[^>]+>|racadm>>)/, timeout => 60) # Wait for prompt
$bmc.set_expected_prompt(/\Rracadm>>/)
$bmc.pwp('racadm') # Not needed on newer iDRAC but does no real harm
# Use HTML5 VirtualConsole
$bmc.pwp('set iDRAC.VirtualConsole.PluginType HTML5')
## BIOS setup
# Disable HyperThreading
$bmc.pwp('set BIOS.ProcSettings.LogicalProc Disabled')
# Use PerfOptimized system profile
$bmc.pwp('set BIOS.SysProfileSettings.SysProfile PerfOptimized')
# Create job to setup BIOS on reboot
$bios_setup_jid = $bmc.pwp('jobqueue create BIOS.Setup.1-1') ? {
/^Commit JID = JID_(\d+)$/ => "JID_${1}",
default => fail('Cannot create BIOS.Setup.1-1 job'),
}
if $reboot {
$bmc.pwp('serveraction powercycle')
# Check the job status until regex matches or timeout happens.
# Do 20 tries, sleeping 15 sec before next try.
$bmc.pwp_until("jobqueue view -i ${bios_setup_jid}", /^Message=\[PR19:/, interval => 15, limit => 20).lest || {
fail("Job ${bios_setup_jid} doesn't succeed in time")
}
}
}
}
For detailed information on functions and types, see REFERENCE.md.
See the LICENSE file in this repository for terms and conditions.