Project

General

Profile

Parameterized class support » History » Version 14

Laurent Domb, 04/01/2014 01:14 PM
fixed typo

1 1 Greg Sutcliffe
h1. Parameterized class support in Foreman
2
3
{{toc}}
4
5
The latest version of Foreman brings parameterized class support to the UI. This document is a walkthrough of setting up the required steps.
6
7
h2. Requirements
8
9
* Foreman 1.1+
10
* Foreman-Proxy 1.1+
11
* Puppet 2.6.5+
12
13 13 Ohad Levy
h2. Screencast
14
15
{{youtube(Ksr0tilbmcc)}}
16
17
18 1 Greg Sutcliffe
h2. Setup
19
20 6 Greg Sutcliffe
Firstly, you'll need to enable the PCS support. Go to More->Settings, select the Puppet tab, and ensure Parametrized_Classes_in_ENC" is set to True. 
21 1 Greg Sutcliffe
22 8 Greg Sutcliffe
!PCS_settings.png!
23 1 Greg Sutcliffe
24 2 Greg Sutcliffe
Now you'll need to import some parameterized classes from your puppet master. You can skip this if you already have parameterized modules on your master, but since the [[Using_Puppet_Module_ready_to_use|foreman-installer]] has several such classes, we'll use those for this example. Assuming default paths (adjust this as necessary):
25 1 Greg Sutcliffe
26
    cd /etc/puppet/modules/production
27
git clone --recursive https://github.com/theforeman/foreman-installer -b develop
28
29
Now import your classes via the Foreman Proxy. Go to More-> Puppet Classes and click Import. If all goes well you'll get a screen showing the classes that are to be imported. Accept the changes, and you should return to the Puppet Classes page, with all the new classes listed.
30
31 7 Greg Sutcliffe
!imported_classes.png!
32 1 Greg Sutcliffe
33
h2. Configure a class
34
35
We'll work with the "foreman" class from the installer. Click on the foreman class, and you should get a page with 3 tabs, like so:
36
37 9 Greg Sutcliffe
!PCS_3tabs.png!
38 1 Greg Sutcliffe
39
The midddle tab, "Smart Class Parameter", is the important one. Click onto that, and you should see something like this:
40
41 9 Greg Sutcliffe
!PCS_edit_params.png!
42 1 Greg Sutcliffe
43
On the left we have a list of possible parameters that the class supports. On the right, we have the configuration options for the parameter selected.
44
45
Lets configure the foreman class to change the user the foreman processes run as. Select the "user" parameter, at the end of the list. Now lets go through the options:
46
47
* Puppet Environments / Name
48
  These can't be edited, they're just for information.
49
* Description
50
  Purely information textbox for making notes in. Not passed to puppet, or reused anywhere else
51
* Override (*important*)
52
  If this is unchecked, Foreman will not attempt to control this variable, and it will not be passed to Puppet via the ENC.
53
* Type
54 3 Greg Sutcliffe
  The type of data we want to pass. Most commonly a string, but many other data types are supported. There's no easy way to tell what type of data puppet is expecting, so you will need to read through the code/documentation that comes with a particular module to find out
55 1 Greg Sutcliffe
* Default Value
56
  This will be imported from puppet initially, but if puppet is using any class inheritance, you'll get something unhelpful like "${$foreman::params::user}". This is because Foreman won't follow the inheritance, so you'll need to set a sensible default value
57
58
Ok, so let's configure our "user" parameter. We want to tick Override, set type to "String" and set the default value to "foreman", like so:
59
60 9 Greg Sutcliffe
!PCS_configure_user.png!
61 1 Greg Sutcliffe
62
h2. Setting up Matchers
63
64
We've configured the default, but that's not very useful. We need to be able to override the default for hosts or groups of hosts. To do that we need the "Override Value For Specific Hosts" section at the bottom of the page.
65
66
Let's say that any machine in the "development" puppet environment should use a value of "foremandev" instead of "foreman" for the "user" parameter. Add "environment" to the end of the matchers list, then click the "New Matcher-Value" button, and fill it out like this:
67
68
    Match: environment = development
69
Value: foremandev
70
71 10 Greg Sutcliffe
!PCS_matcher_env.png!
72 1 Greg Sutcliffe
73
This is a basic configuration - for more complex examples of using matchers, see the SmartVariables page.
74
75
h2. Complex Data
76
77
Here's a screenshot of adding an array parameter. Note the use of YAML in the editbox:
78
79 11 Greg Sutcliffe
!PCS_complex_data.png!
80
81 14 Laurent Domb
This will be converted to the normal ["a","b"] syntax when you save. You can also use Hashes, YAML or JSON as data types too.
82 1 Greg Sutcliffe
83
h2. Editing Param from within a Host
84
85 5 David Schmitt
If foreman manages the value of a class parameter ("override"), it's also possible to update a host-specific override from the host itself. That way you don't have to grant access to the Puppet Classes page to everyone. From a Host, click Edit, go to the Parameters tab, and you'll see the variable, the class-scope, and the current value. You can then override the value for that host:
86 1 Greg Sutcliffe
87 12 Greg Sutcliffe
!PCS_edit_host.png!
88 1 Greg Sutcliffe
89
If you go back and look at the Puppet class, you'll see Foreman has added a matcher for that host:
90
91 12 Greg Sutcliffe
!PCS_match_override.png!
92 1 Greg Sutcliffe
93
Currently this only works for Hosts, not Hostgroups. For more complex logic, like matching on facts, use the Puppet Class page
94
95
h2. Input Validation
96
97
The "Optional Input Validation" section can be used to restrict the allowed values for the parameter. This functions in the same way as for SmartVariables, but it is important to note that the validation applies to changes made from the Host edit page as well as the Puppet Classes edit page. 
98
99
For example, to restrict the "user" field to either "foreman" or "foremandev", tick the Required checkbox, and then set:
100
101
    Type: List
102
Rule: foreman,foremandev