Plans in PE versus Bolt plans
Some plan language functions, features, and behaviors are different in PE than they are in Bolt. If you are used to Bolt plans, familiarize yourself with some of these key differences and limitations before you attempt to write or run plans in PE.
Apply blocks
The apply
feature, including apply_prep
,
only works for targets using the PXP agent and the PCP transport. It fails on remote devices
and on targets connected via SSH or WinRM.
Target groups
add_to_group
causes a plan to fail and referencing a group name in
get_targets
doesn't return any nodes. When using
get_targets
you must reference either node certnames or supply a PuppetDB query. Here is an example of a plan using
get_targets
with node
certnames:plan example::get_targets_example () {
$nodes = get_targets([‘node1.example.com’, ‘node2.example.com’])
run_command(‘whoami’, $nodes)
}
Target behaviors
- A connected agent with a certname
- An entry in the PE inventory service
New targets cannot be added to the inventory service inside a plan. New target objects created in plans can't connect because PE doesn't recognize them.
Targets return an empty hash when asked about connection information.
Target configuration
While you can set up node transport configuration through the PE inventory for nodes to use SSH or WinRM, you can't change
the configuration settings for targets from within a plan. Using the
set_config
function in a plan causes the plan to fail and referencing a
target object’s configuration hash always returns an empty hash.
The use of URIs in a target name to override the transport is also not supported.
All references to targets (i.e. when using get_targets
) must be either PuppetDB queries or valid certnames that are already in the PE inventory.
get_targets
correctly:plan example::get_targets_example () {
## NOTE! If you used ssh://node1.example.com as the first entry, this plan would fail!
$nodes = get_targets([‘node1.example.com’, ‘node2.example.com’])
run_command(‘whoami’, $nodes)
}
The localhost
target
The special target localhost
is not available for plans in PE. Using localhost
anywhere in a plan results
in a plan failure. If you need to run a plan on the primary server host, use the primary
server's certname to reference it.
my-primary-server.company.com
:plan example::referencing_the_primary_server(){
# Note that if you tried to use `localhost` instead of `my-primary-server` this plan would fail!
run_command(‘whoami’, ‘my-primary-server.company.com’)
}
The _run_as
parameter
Plans in PE do not support the _run_as
parameter for changing the user that accesses hosts or executes actions. If this parameter
is supplied to any plan function, the plan runs but the user doesn't change.
other_user
:plan example::run_as_example (TargetSpec $nodes) {
run_command(‘whoami’, $nodes, _run_as => ‘other_user’)
}
Script and file sources
When using run_script
or file::read
, the
source location for the files must be from a module that uses a modulename/filename
selector for a file or directory in
$MODULEROOT/files
. PE doesn't support file
sources that reference absolute paths.
modulename/filename
selector:example/
├── files
└──my_script.sh
└── plans
└──run_script_example.pp
plan example::run_script_example (TargetSpec $nodes) {
run_script(‘example/my_script.sh’, $nodes)
}
Code deployment for plans
Using plans in PE requires Managing code with Code Manager. You must enable Code Manager to deploy code to your primary server.
codedir
from
which plans load code. This secondary code location on your primary server impacts standard
module functionality:- You can't use the
puppet module install
command to install modules for plans, because thepuppet module
tool can't install to the plancodedir
. However, thepuppet module install
command works as usual for non-plan Puppet code executed and compiled from Puppet Server. - A
$modulepath
configuration that uses fully qualified paths might not work for plans if they reference the standard/etc/puppetlabs/code
location. It is more reliable to use relative paths in$modulepath
.