standard
Version information
This version is compatible with:
- Puppet Enterprise 2023.8.x, 2023.7.x, 2023.6.x, 2023.5.x, 2023.4.x, 2023.3.x, 2023.2.x, 2023.1.x, 2023.0.x, 2021.7.x, 2021.6.x, 2021.5.x, 2021.4.x, 2021.3.x, 2021.2.x, 2021.1.x, 2021.0.x
- Puppet >= 7.0.0 < 9.0.0
Start using this module
Add this module to your Puppetfile:
mod 'kb-standard', '0.0.2'
Learn more about managing modules with a PuppetfileDocumentation
Standard
table of contents
- module description – what the module does and why it is useful
- setup – the basics of getting started with
standard
- limitations – OS compatibility, etc.
- development – guide for contributing to the module
module description
- This module provides a select collection of standardized functions and data types within the Puppet ® ecosystem. If you are familiar with the referenced standards, e. g. POSIX™ or RFC number so‑and‑so, you will know how something works. Minor extensions that amount to de‑facto standards are provided, too, and there are some bonus templates.
- “You write code for humans.” Identifiers are kept human‐readable: No abbreviations are used. Particularly in a large code base the function of objects should be apparent without consulting other sources.
setup
what standard
affects
The standard
module affects nothing (except occupying the standard
identifier/namespace, duh!).
setup requirements
There are no setup requirements.
beginning with standard
Simply put the module data at its right location and use the functions, data types or templates it provides.
There are no manifests. You cannot include
this module.
limitations
The standard
module has a number of limitations:
- Implementation limitations are documented in the
reference.md
. - There is no
Standard::InternetProtocolVersion6address
data type. ☹ - Not everything that was desired/considered for inclusion is indeed formally standardized.
- Standards that focus on one operating system are deliberately ignored (e. g. ISO/IEC 23360‑* “Linux Standard Base”).
development
- Make your case (how is something useful for a system managed by Puppet), reference specific sections of standards, if possible provide implementation and documentation, and do not forgot a copyright statement (public domain) in the commit message(s) of any commit(s) you may provide.
- Note, this module focuses on free open‐source systems. Access to standards needs to be royalty‐free (cmp. ISO standards).
reference
For quick reference an example value has been provided too:
- data types
Standard::AbsoluteDirectoryName
–'/.'
Standard::AbsolutePathname
–'/dev/urandom'
Standard::FileMode
–01755
Standard::Filename
–'.'
Standard::FQDN
–'puppet.com.'
Standard::FullyQualifiedDomainName
–'puppetlabs.com.'
Standard::InternetProtocolVersion4address
–134743044
Standard::Line
–"Hello world!\n"
Standard::NormalizedPortableAbsolutePathname
–'/dev/null'
Standard::OrdinaryPortableFilename
–'rc.conf'
Standard::OrdinaryPortableFilenameDictionary
–{'abc' => 'def'}
Standard::PartiallyQualifiedDomainName
–'puppetlabs.com'
Standard::Pathname
–'.profile'
Standard::PortableAbsoluteDirectoryName
–'/etc/.'
Standard::PortableAbsolutePathname
–'/dev//urandom'
Standard::PortableFilename
–'..'
Standard::PortableGroupName
–'wheel'
Standard::PortablePathname
–'.profile'
Standard::PortableRelativePathname
–'..'
Standard::PortableUserName
–'root'
Standard::PQDN
–'puppet.com'
Standard::ShellCommandLanguageName
–'LC_ALL'
Standard::SpecialFilename
–'..'
Standard::SpecialPortableFilename
–'..'
Standard::SymbolicFileModeBits
–'u=rwx,go=rx'
Standard::SystemErrorLogFacility
–'LOG_DAEMON'
Standard::SystemErrorLogPriority
–'LOG_ERR'
Standard::VisiblePortableCharacterSetString
–'&'
- functions
standard::directory_name
–'/'
standard::dotted_decimal
–'123.456.789'
standard::internet_protocol_version_4_address
–134743044
- templates
standard/character_set_description.epp
– (too long)standard/shell_variable_assignments.epp
–'VARIABLE=word'
data types
pathnames:
- absolute
Standard::AbsoluteDirectoryName
– ends on/.
Standard::AbsolutePathname
Standard::NormalizedPortableAbsolutePathname
– no repeating slashesStandard::PortableAbsoluteDirectoryName
Standard::PortableAbsolutePathname
– no weird characters
- relative
Standard::PortableRelativePathname
– not beginning with/
Standard::PortableFilename
Standard::SpecialFilename
– same or parent directoryStandard::SpecialPortableFilename
- either
Standard::Filename
– a directory, a regular file, or anything elseStandard::OrdinaryPortableFilename
– excludes same or parent directoryStandard::Pathname
– just a stringStandard::PortablePathname
– just a string restricted to certain characters
- map
file mode bits:
Standard::FileModeBits
– symbolic or numeric file mode bitsStandard::SymbolicFileModeBits
– only symbolic file mode bits
user and group names:
networking:
Standard::FQDN
– alias for fully‑qualified domain nameStandard::FullyQualifiedDomainName
Standard::InternetProtocolVersion4address
– an integer rangeStandard::PartiallyQualifiedDomainName
Standard::PQDN
– alias for partially‑qualified domain name
data:
Standard::ShellCommandLanguageName
Standard::Line
– a string that constitutes a lineStandard::SystemErrorLogFacility
Standard::SystemErrorLogPriority
Standard::VisiblePortableCharacterSetString
Standard::AbsoluteDirectoryName
description:
- This is like
Standard::AbsolutePathname
except that it must end with slash‐dot (/.
) thus (unambiguously) identifying a directory. - Some authors use just a trailing slash to denote directories. This, however, merely distinguishes a symbolic link (i. e. the file that implements the symbolic link) vs. the resolved symbolic link (i. e. the target a symbolic link points to). If the resolved symbolic link does not point to a directory, an error is emitted.
- The final dot is added so that the standardized
dirname
utility (return the directory portion of a pathname) returns the directory file name.
examples:
'/.'
compliance:
- POSIX.1‑2024
- The notion of “absolute directory name” is not mentioned explicitly.
- ✘ Pathnames ending on
'/..'
are not accepted. It is assessed to be more likely a mistake.
Standard::AbsolutePathname
description:
- This is
Standard::Pathname
except that it must start with one or more than two slashes (/
).
examples:
'/x/y/z'
'/home/example_user/文件'
'////'
compliance:
- POSIX.1‑2024
- ✔ begins with one or more than two slash (
/
) characters
- ✔ begins with one or more than two slash (
Standard::FileModeBits
description:
- A filemode is either a non‐negative
Integer
≤ 7777₈ orStandard::SymbolicFileModeBits
.
example:
0644
compliance:
- POSIX.1‑2024
- ✔ the
Integer
variant corresponds tomode_t
- ✔ the
Standard::Filename
description:
- A filename is a non‐empty sequence of bytes excluding the values for NUL and slash (
/
).
examples:
'Meine Überdatei²'
"Robert'); DROP TABLE Students;"
compliance:
- POSIX.1‑2024
- ✔ Note this data type cannot observe the
NAME_MAX
length limit. On a POSIX‐compliant system this value is at least 14 (fourteen) bytes.
- ✔ Note this data type cannot observe the
Standard::FullyQualifiedDomainName
description:
- This data type provides a very limited subset of possible FQDNs.
It is a
String
data type implemented via regular expressions. It matches up to five labels plus a final empty label (the root label). Labels are separated from each other by a single dot (.
). - A label is a non‐empty sequence of up to 63 ASCII letters or digits (A – Z, a – z, 0 – 9).
- The first character must be a letter.
- In the middle dashes (
-
) may appear too.
- The entire string’s length may not exceed 255 characters. Due to the implementation via regular expressions (as a compromise) the labels’ maximum length varies if five labels need to be specified (57, 56, 56, 56, 24). The limits are subject to adjustment.
- In many contexts in fact a fully‐qualified domain name is expected
but the terminating separator for the root label is treated as an error.
Use the built‑in
chop
function to remove the root label separator, or useStandard::PartiallyQualifiedDomainName
if a (as in any) PQDN is acceptable, too.
examples:
'forge.puppet.com.'
'xn--7qv.xn--ses554g.'
'1.0.0.127.IN-ADDR.ARPA.'
limited compliance:
- RFC 1035
- ✔ “The domain name terminates with the zero length octet for the null label of the root.”
- ✔ Labels are composed of ASCII letters and digits.
- ✔ “The labels must follow the rules for ARPANET host names. They must start with a letter, end with a letter or digit, and have as interior characters only letters, digits, and hyphen.”
- ✔ “Labels must be 63 characters or less.”
- ✔ “[…] the total length of a domain name […] is restricted to 255 octets or less.”
- ✔ “
IN-ADDR.ARPA
domain” - ✘
Standard::FullyQualifiedDomainName
is capped to to six labels (including the root label). Technically it ought to be possible to accept up to 127 labels.
Standard::FQDN
description:
- This is an alias for
Standard::FullyQualifiedDomainName
. If the context implies the meaning of the acronym FQDN, you may use this identifier. However, its removal (e. g. outsourcing to a different module focusing on network management) is considered.
Standard::InternetProtocolVersion4address
description:
- This is a non‐negative integer less than 2³².
examples:
2130706433
0xFEDCBA98
compliance:
- POSIX.1‑2024
- ✔ corresponds to
in_addr_t
(which is equivalent touint32_t
)
- ✔ corresponds to
- RFC 791
Standard::InternetProtocolVersion4address
is at least a 32‑bit quantity.
Standard::Line
description:
- A line is a possibly empty sequence of non‐newline characters concluding with a single newline character.
example:
"Hello world!\n"
compliance:
- POSIX.1‑2024
Standard::NormalizedPortableAbsolutePathname
description:
- This is
Standard::PortableAbsolutePathname
, but it may not contain consecutive slash characters. - It has not yet been decided
whether this application case should be implemented via a custom data type (a regular expression to be precise)
or whether a (set of) function(s) would be more adequate.
Deliberation is mainly driven by considering which situations should lead to a catalog compilation failure.
Evidently
'/foo///bar'
is a valid pathname and will be accepted by the operating system.
Standard::OrdinaryPortableFilename
description:
- The filenames
'.'
and'..'
are special (conveying same directory and parent directory respectively). This data type isStandard::PortableFilename
but it does not match said special filenames.
example:
'rc.conf'
limited compliance:
- POSIX.1‑2024
- The notion of “ordinary portable filename” is not expressly defined.
- This data type cannot observe the
NAME_MAX
limit (the minimum is 14).
Standard::OrdinaryPortableFilenameDictionary
description:
- This is merely a
Hash
that hasStandard::OrdinaryPortableFilename
both as key and value.
examples:
{}
{'std' => 'standard'}
no compliance:
- This is a convenience definition not backed by specfic standard definitions.
Standard::PartiallyQualifiedDomainName
description:
- This is
Standard::FullyQualifiedDomainName
but a final dot must be absent. Accordingly the length is capped at 254 characters. - To be logically consistent
IN-ADDR.ARPA
addresses are not available. The root domain (that is the string'.'
) cannot be specified either.
examples:
'www.example.com'
'forge.puppet.com'
compliance:
- See
Standard::FullyQualifiedDomainName
with the exception of a final dot in mind.
Standard::PQDN
description:
- This is an alias for
Standard::PartiallyQualifiedDomainName
. If the context implies the meaning of the acronym PQDN, you may use this identifier. - Notice: A removal (outsourcing to a different module focusing on network management) is considered.
Standard::Pathname
description:
- This is a
String
data type. Strings must be non‐empty. - A terminating NUL character is implicit and must not be indicated.
example:
'קובץ'
compliance:
- POSIX.1‑2024
- ✔ Note, there is no observance of
PATH_MAX
. On a POSIX‐compliant systems this is at least 256 bytes.
- ✔ Note, there is no observance of
Standard::PortableAbsoluteDirectoryName
description:
- This is like
Standard::PortableAbsolutePathname
except that it must end with slash‐dot (/.
) thus (unambiguously) identifying a directory. - Some authors use just a trailing slash to denote directories. This distinguishes a symbolic link (i. e. the file that implements the symbolic link) vs. the resolved symbolic link (i. e. the target a symbolic link points to). If the resolved symbolic link does not point to a directory, an error is emitted.
- The final dot is added so that the standardized
dirname
utility (return the directory portion of a pathname) returns the directory file name.
examples:
'/etc/rc.conf.d/.'
compliance:
- POSIX.1‑2024
- The notion of “portable absolute directory name” is not mentioned explicitly.
- ✘ Pathnames ending with
'/..'
are not accepted. It is assessed to be more likely a mistake.
Standard::PortableAbsolutePathname
description:
- This is
Standard::PortablePathname
except that it must start with one or more than two slashes (/
).
examples:
'/var/log//kern.log'
compliance:
- POSIX.1‑2024
- ✔ begins with one or more than two slash (
/
) characters
- ✔ begins with one or more than two slash (
Standard::PortableFilename
description:
- Filenames are a non‐empty sequence of characters except slashes and NUL‐characters. This data type is restricted to the “portable filename character set” thus only modern Latin alphabet letters, Western‐Arabic digits, underscores, dots, and dashes are accepted.
- Note, filenames starting with a dash (
-
) are accepted. They may cause troubles on the command line interface if supplied as the first component of a working‐directory‐relative pathname.
examples:
'..'
'crash.dump'
compliance:
- POSIX.1‑2024
- ✔ Note this data type cannot observe the
NAME_MAX
length limit. On a POSIX‐compliant system this value is at least 14 (fourteen) bytes.
- ✔ Note this data type cannot observe the
Standard::PortablePathname
description:
- A portable pathname is a
Standard::Pathname
restricted to the portable filename character set and slash characters. A terminating NUL character is not indicated.
examples:
'//proxy
compliance:
- POSIX.1‑2024
- ✔ with the consideration of NUL characters
Standard::PortableGroupName
description:
- This is identical to
Standard::PortableUserName
. This data type is primarily provided for documentation purposes.
example:
'wheel'
compliance:
- POSIX.1‑2024
Standard::PortableRelativePathname
description:
- This is
Standard::PortablePathname
except that it may not start with a slash.
examples:
'./reference.md'
'puppet/../..'
compliance:
- POSIX.1‑2024
- ✔ does not begin a slash (
/
) character
- ✔ does not begin a slash (
Standard::PortableUserName
description:
- A portable user name is a non‐empty string composed of ASCII letters and digits, dots, underscores, and dashes. The first character may not be a dash. (A leading dash usually indicates an option in the command‐line interface.)
- This data type accepts all‐numeric user names, too, and they should be accepted for interoperability reasons, but for new user names it is recommended to restrict the set of acceptable user names even further: humans may confuse reported digit strings for the numeric user ID, and some command‐line tools do not allow you to specify a numeric user ID anymore if it coincides with a user’s name.
example:
'puppet'
compliance:
- POSIX.1‑2024
- ✔ Note that the
LOGIN_NAME_MAX
length limit cannot be observed. On a POSIX‐compliant system this limit permits at least 8 characters for a user name. For maximum portability cap your user names at eight characters.
- ✔ Note that the
Standard::ShellCommandLanguageName
description:
- A name in the (POSIX) shell command language. It consists of a non‐empty sequence of modern Latin alphabet characters, Western‐Arabic digits, and underscores. The first character, however, may not be a digit.
examples:
'foobar'
'LD_SHOW_AUXV'
compliance:
- POSIX.1‑2024
- ✔ fully‐compliant to “name” as specified in the Base Definitions
Standard::SpecialFilename
description:
- The file names
'.'
and'..'
have special meaning conveying current directory or parent directory respectively. - This data type is primarily provided for meaningful
=~
data type matching.if $my_value =~ Standard::SpecialFilename { fail('$my_value may not be special.') }
all values:
'.'
'..'
compliance:
- POSIX.1‑2024
- the category of special file name is inferred
Standard::SpecialPortableFilename
description:
- This is an alias for
Standard::SpecialFilename
. However, use of this identifier can be deemed confusing since “portable” does not add any quality to the permitted values. It is only provided to supply an orthogonal set of identifiers.
Standard::SymbolicFileModeBits
description:
- A spelled out file mode bits description suitable as
mode
attribute of afile
resource or for tools such aschmod
.
example:
'u=rw,go=r'
(the owning user has read and write permissions, the owning group and others have read permissions)
compliance:
- POSIX.1‑2024
- ✔ fully‐compliant to
symbolic_mode
described inchmod
.
- ✔ fully‐compliant to
Standard::SystemErrorLogFacility
description:
- A symbolic constant name for a system error log facility.
example:
'LOG_DAEMON'
compliance:
- POSIX.1‑2024
- The Puppet ® data type matches string values, but should be identifiers. You cannot specify valid values as bare words, though, since the first letter is a capital letter.
Standard::SystemErrorLogPriority
description:
- A symbolic constant name for a system error log priority.
example:
'LOG_DEBUG'
compliance:
- POSIX.1‑2024
- The Puppet ® data type matches string values, but should be identifiers. You cannot specify valid values as bare words, though, since the first letter is a capital letter.
Standard::VisiblePortableCharacterSetString
description:
- A non‑empty string consisting solely of character drawing from the visible portion of the portable character set.
example:
'?'
compliance:
- POSIX.1‑2024
- The notion of a visible PCS string is not explicitly defined.
functions
pathnames:
standard::directory_name
– obtain directory name from string
networking:
standard::dotted_decimal
– turn an integer into a stringstandard::internet_protocol_version_4_address
– numeric value from string
standard::directory_name
description:
- This is a wrapper for Ruby’s
File.dirname
function.
example:
standard::directory_name('//foo')
returns'/'
compliance:
- POSIX.1‑2024
- Ruby documentation does not make any assertions
and the implementation has not been verified,
but it is expected to correspond to the
dirname
function
- Ruby documentation does not make any assertions
and the implementation has not been verified,
but it is expected to correspond to the
standard::dotted_decimal
description:
- This function takes a non‐negative integer and converts it to a string using the dotted decimal notation.
- The second integer parameter denotes the maximum range per group. It must be greater than one (
1
). - The optional third positive integer parameter will augment leading zero‐groups.
examples:
standard::dotted_decimal(0xFF00, 256)
yields'255.0'
standard::dotted_decimal(0x7F000001, 256, 4)
yields'127.0.0.1'
compliance:
- POSIX.1‑2024
- If invoked as
standard::dotted_decimal($n, 256, 4)
this corresponds toinet_ntoa
in functionality unless$n
exceeds the value of0xFFFFFFFF
.
- If invoked as
standard::internet_protocol_version_4_address
description:
- The function takes a non‐empty string containing hexadecimal digits, the letter
x
and dots.
examples:
standard::internet_protocol_version_4_address('127.123.45678')
yields2138813038
standard::internet_protocol_version_4_address('255.255.255.255')
yields4294967295
compliance:
- POSIX.1‑2024
- ✔ This function corresponds to
inet_addr
. - ✔ accepts octal, decimal, hexadecimal parts
- ✔ up to four parts with shift applied
- ✔ This function corresponds to
templates
programming languages:
standard/shell_variable_assignments.epp
– shell variable assignments
data:
standard/character_set_description.epp
– character set description file
standard/character_set_description.epp
description:
- Two character set description files can be supplied to the standardized
iconv
utility. This allows you to translate between character set encodings, provided all input coded characters are defined in both sets. - The template requires two parameters,
code_set_name
andmap
. Thecode_set_name
is aStandard::VisiblePortableCharacterSetString
. Themap
is a non‑emptyHash
. The keys must matchStandard::VisiblePortableCharacterSetString
. The values are either non‑empty arrays of byte values (integers in the range 0 to 255 inclusive), or anotherHash
. If it is anotherHash
, there must be a keyencoding
that is a non‑empty array of byte values. There may be additional keyswidth
andcomment
. Thewidth
is anInteger
value and comment is aString
. - The parameters
mb_cur_min_
,mb_cur_max
anddefault_width
are by default all1
. - You can supply alternative parameter values for
comment_char
andescape_char
. However, there are only few characters accepted because of existent implementations. For example a GNU C library version oficonv
does/did not accept;
(semicolon) as a comment character. - Furthermore, the template accepts the optional parameters
comment
andfooter
. The former is a commented string appearing above theCHARMAP
. The latter is a commented string appearing at the end of the file. Ifcomment
is leftundef
ined, a column header line is printed if it is determined to align with the columns. - You can influence formatting:
The
Integer
parametercolumn_symbolic_name_minimum_width
is by default32
. TheInteger
parametercolumn_byte_string_minimum_width
is by default16
. Adjust them to your taste.
example:
-
epp('standard/character_set_description.epp', {code_set_name => 'ABC', map => {'X' => [42]}})
yields<code_set_name> "ABC" # symbolic_name, byte string, comment CHARMAP <X> \052 END CHARMAP
compliance:
- POSIX.1‑2024
- Because the domains of
comment_char
andescape_char
are restricted to a few characters, this template can render a only a subset of possible character maps. - This template does in no way ensure that all characters of the portable character set are part of
map
. (“Each character set description file […] shall define characteristics for the coded character set and the encoding for the characters specified in Portable Character Set […]”)
- Because the domains of
standard/shell_variable_assignments.epp
description:
- Applications employing the KISS principle frequently use shell‐based configuration files if there is no demand for complicated constructs.
- This template provides a quick way to fill a file with a host of variable assignments.
The mandatory parameter
$setting
is aHash
. Acceptable keys areStandard::ShellCommandLanguageName
. Acceptable values areScalarData
(that isBoolean
,Integer
,Float
andString
data types). - Integer, float and Boolean values are rendered using the automatic conversion mechanisms Puppet ® provides.
Optional
$integer_format
,$float_format
and$boolean_format
string parameters may override this. See Puppet’s function reference for details. - Strings are surrounded by inch signs (
"
) if they contain anything to expand (e. g. shell variables), otherwise typewriter apostrophes ('
) are used. - It is recommended to verify that the application at hand uses a shell‐based configuration by design, or whether its resemblance is a mere coincidence (and thus a later application version may significantly deviate from it).
example:
epp('standard/shell_variable_assignments.epp', {$setting => {'FOO' => 'bar'}})
yieldsFOO='bar'
limited compliance:
- POSIX.1‑2024
- It has not been established that it is impossible to pass values
that will render this template’s output invalid shell input.
Therefore setting
validate_cmd
to'/bin/sh ‑o noexec %'
is recommended.
- It has not been established that it is impossible to pass values
that will render this template’s output invalid shell input.
Therefore setting