CFEngine docs homepage
  • Product
  • Blog
  • Docs versions
    Version
    master 3.24 (LTS) 3.21 (LTS) view all versions
  • Try for free
  • Home
  • /
  • Examples and tutorials
  • /
  • Example snippets

Example snippets

Suggest changes
  • General examples
  • Administration examples
  • Measuring examples
  • Software administration examples
  • Commands, scripts, and execution examples
  • File and directory examples
  • File template examples
  • Database examples
  • Network examples
  • System security examples
  • System information examples
  • System administration examples
  • System file examples
  • Windows registry examples
  • User management

Still need help?

Chat Ask a question on Github Mailing list
Version 
master 3.24 (LTS) 3.21 (LTS) view all versions
    • Overview
      • What is CFEngine and why?
      • How CFEngine works
      • CFEngine directory structure
      • Client server communication
      • Glossary
    • Getting started
      • Installation
        • Pre-installation checklist
          • Quick-Start guide to using vi
          • Quick-Start guide to using PuTTY
          • Verifying package signatures
        • Local virtual machine
        • General installation
          • Using Amazon Web Services
          • Installing Enterprise 25 Free
          • Using Vagrant
          • Installing Enterprise on CoreOS
          • Installing Enterprise for production
          • Installing Community
          • Installing from binary tarball
          • Installing Community Using Containers
        • Secure bootstrap
        • Installation overview
        • Upgrading
        • Version control
      • Modules from CFEngine Build
      • Reporting and web UI
      • Writing policy
      • Developing modules
    • Release notes
      • New in CFEngine
        • Changelog
        • Masterfiles changelog
        • Enterprise changelog
      • Supported platforms and versions
      • Known issues
      • Legal and licenses
    • Web UI
      • Settings
      • Health
      • Hosts
      • Alerts and notifications
      • Custom actions for alerts
      • Enterprise reporting
        • Reporting architecture
        • SQL queries using the Enterprise API
        • Reporting UI
        • Client initiated reporting / call collect
      • Federated reporting
      • Measurements app
      • Hub administration
        • Decommissioning hosts
        • Extending Mission Portal
        • Extending query builder in Mission Portal
        • Adjusting schedules
        • Backup and restore
        • Custom SSL certificate
        • Configure a custom LDAP port
        • Custom LDAPs certificate
        • Enable plain http
        • Lookup license info
        • Policy deployment
        • Public key distribution
        • Regenerate self signed SSL certificate
        • Re-installing Enterprise hub
        • Reset administrative credentials
      • Debugging Mission Portal
      • License
    • API
      • Enterprise API examples
        • Checking status
        • Managing settings
        • Managing users and roles
        • Browsing host information
        • Tracking changes
        • SQL query examples
      • Enterprise API reference
        • Actions API
        • AI chat API
        • AI settings API
        • Audit log API
        • Build API
        • Changes REST API
        • CMDB API
        • Import & export API
        • Import & export compliance report API
        • Federated reporting configuration API
        • File changes API
        • Fist time setup API
        • Health diagnostic API
        • Host REST API
        • Inventory API
        • LDAP authentication API
        • Personal groups API
        • Query REST API
        • Reset password API
        • Shared groups API
        • SQL schema
          • cfdb
          • cfmp
          • cfsettings
        • SSH keys API
        • Status and settings REST API
        • Two-factor authentication API
        • Users and access-control REST API
        • VCS settings API
        • Web RBAC API
    • Examples and tutorials
      • Example snippets
        • General examples
        • Administration examples
        • Common promise patterns
          • Aborting execution
          • Change detection
          • Copy single files
          • Create files and directories
          • Check filesystem space
          • Customize message of the day
          • Set up name resolution with DNS
          • Ensure a service is enabled and running
          • Find the MAC address
          • Install packages
          • Mount NFS filesystem
          • Set up time management through NTP
          • Ensure a process is not running
          • Restart a process
          • Distribute ssh keys
          • Set up sudo
          • Updating from a central policy server
        • Measuring examples
        • Software administration examples
        • Commands, scripts, and execution examples
        • File and directory examples
        • Interacting with directory services
        • File template examples
        • Database examples
        • Network examples
        • System security examples
        • System information examples
        • System administration examples
        • System file examples
        • Windows registry examples
        • File permissions
        • User management examples
      • Tutorials
        • JSON and YAML support in CFEngine
        • Installing CFEngine Enterprise agent
        • Managing local users
        • Managing network time protocol
        • Package management
        • Managing processes and services
        • Writing CFEngine policy
        • Distributing files from a central location
        • File editing
        • Reporting and remediation of security vulnerabilities
        • Masterfiles Policy Framework upgrade
        • Tags for variables, classes, and bundles
        • Custom inventory
        • Dashboard alerts
        • Integrating alerts with PagerDuty
        • Integrating alerts with ticketing systems
        • Integrating with Sumo Logic
        • Rendering files with Mustache templates
        • Reporting
          • Monitoring and reporting
          • Command-Line reports
        • File comparison
        • High availability
          • Installation guide
        • Writing and serving policy
          • Layers of abstraction in policy
          • Promises available in CFEngine
          • Authoring policy tools & workflow
          • Editors
          • Policy style guide
          • Bundles best practices
          • External data
          • Testing policies
          • Controlling frequency
    • Reference
      • Components
        • cf-agent
        • cf-secret
        • cf-support
        • cf-serverd
        • cf-execd
        • cf-promises
        • cf-monitord
        • cf-key
        • cf-runagent
        • cf-check
        • cf-hub
        • cf-net
        • cf-reactor
        • file control
      • Promise types
        • access
        • classes
        • commands
        • custom
        • defaults
        • files
          • edit_line
            • delete_lines
            • field_edits
            • insert_lines
            • replace_patterns
          • edit_xml
            • build_xpath
            • delete_attribute
            • delete_text
            • delete_tree
            • insert_text
            • insert_tree
            • set_attribute
            • set_text
        • measurements
        • meta
        • methods
        • packages (deprecated)
        • packages
        • processes
        • reports
        • roles
        • services
        • storage
        • users
        • vars
        • databases
        • guest_environments
      • Functions
        • accessedbefore
        • accumulated
        • ago
        • and
        • basename
        • bundlesmatching
        • bundlestate
        • callstack_callers
        • callstack_promisers
        • canonify
        • canonifyuniquely
        • cf_version_after
        • cf_version_at
        • cf_version_before
        • cf_version_between
        • cf_version_maximum
        • cf_version_minimum
        • changedbefore
        • classesmatching
        • classfiltercsv
        • classfilterdata
        • classify
        • classmatch
        • concat
        • countclassesmatching
        • countlinesmatching
        • data_expand
        • data_readstringarray
        • data_readstringarrayidx
        • data_regextract
        • data_sysctlvalues
        • datastate
        • difference
        • dirname
        • diskfree
        • escape
        • eval
        • every
        • execresult
        • execresult_as_data
        • expandrange
        • file_hash
        • fileexists
        • filesexist
        • filesize
        • filestat
        • filter
        • findfiles
        • findfiles_up
        • findlocalgroups
        • findlocalusers
        • findprocesses
        • format
        • getacls
        • getbundlemetatags
        • getclassmetatags
        • getenv
        • getfields
        • getgid
        • getgroupinfo
        • getgroups
        • getindices
        • getuid
        • getuserinfo
        • getusers
        • getvalues
        • getvariablemetatags
        • grep
        • groupexists
        • hash
        • hash_to_int
        • hashmatch
        • host2ip
        • hostinnetgroup
        • hostrange
        • hostsseen
        • hostswithclass
        • hostswithgroup
        • hubknowledge
        • ifelse
        • int
        • intersection
        • ip2host
        • iprange
        • irange
        • is_type
        • isconnectable
        • isdir
        • isexecutable
        • isgreaterthan
        • isipinsubnet
        • islessthan
        • islink
        • isnewerthan
        • isnewerthantime
        • isplain
        • isreadable
        • isvariable
        • join
        • lastnode
        • laterthan
        • ldaparray
        • ldaplist
        • ldapvalue
        • length
        • lsdir
        • makerule
        • maparray
        • mapdata
        • maplist
        • max
        • mean
        • mergedata
        • min
        • network_connections
        • none
        • not
        • now
        • nth
        • on
        • or
        • packagesmatching
        • packageupdatesmatching
        • parseintarray
        • parsejson
        • parserealarray
        • parsestringarray
        • parsestringarrayidx
        • parseyaml
        • peerleader
        • peerleaders
        • peers
        • processexists
        • product
        • randomint
        • read_module_protocol
        • readcsv
        • readdata
        • readenvfile
        • readfile
        • readintarray
        • readintlist
        • readjson
        • readrealarray
        • readreallist
        • readstringarray
        • readstringarrayidx
        • readstringlist
        • readtcp
        • readyaml
        • regarray
        • regcmp
        • regex_replace
        • regextract
        • registryvalue
        • regldap
        • regline
        • reglist
        • remoteclassesmatching
        • remotescalar
        • returnszero
        • reverse
        • rrange
        • selectservers
        • shuffle
        • some
        • sort
        • splayclass
        • splitstring
        • storejson
        • strcmp
        • strftime
        • string
        • string_downcase
        • string_head
        • string_length
        • string_mustache
        • string_replace
        • string_reverse
        • string_split
        • string_tail
        • string_trim
        • string_upcase
        • sublist
        • sum
        • sysctlvalue
        • translatepath
        • type
        • unique
        • url_get
        • usemodule
        • userexists
        • useringroup
        • validdata
        • validjson
        • variablesmatching
        • variablesmatching_as_data
        • variance
        • version_compare
      • Language concepts
        • Bundles
        • Bodies
        • Promises
        • Policy evaluation
        • Classes and decisions
        • Variables
        • Augments
        • Loops
        • Pattern matching and referencing
        • Modules
          • Package modules
        • Namespaces
      • Special variables
        • connection
        • const
        • def
        • edit
        • match
        • mon
        • sys
        • this
      • Masterfiles Policy Framework
        • promises.cf
        • .no-distrib/
        • update.cf
        • standalone_self_upgrade.cf
        • cfe_internal/CFE_cfengine.cf
        • cfe_internal/core/watchdog/watchdog.cf
        • cfe_internal/core/watchdog
        • cfe_internal/core/
        • cfe_internal/enterprise/federation/federation.cf
        • cfe_internal/enterprise/federation/
        • cfe_internal/enterprise/
        • cfe_internal/recommendations.cf
        • cfe_internal/update/cfe_internal_dc_workflow.cf
        • cfe_internal/update/cfe_internal_update_from_repository.cf
        • cfe_internal/update/lib.cf
        • cfe_internal/update/systemd_units.cf
        • cfe_internal/update/update_bins.cf
        • cfe_internal/update/update_policy.cf
        • cfe_internal/update/update_processes.cf
        • cfe_internal/update/
        • cfe_internal/
        • controls/cf_hub.cf
        • controls/cf_agent.cf
        • controls/cf_execd.cf
        • controls/cf_monitord.cf
        • controls/cf_runagent.cf
        • controls/cf_serverd.cf
        • controls/def.cf
        • controls/def_inputs.cf
        • controls/reports.cf
        • controls/update_def.cf
        • controls/update_def_inputs.cf
        • controls/
        • inventory/any.cf
        • inventory/debian.cf
        • inventory/freebsd.cf
        • inventory/generic.cf
        • inventory/linux.cf
        • inventory/lsb.cf
        • inventory/macos.cf
        • inventory/os.cf
        • inventory/redhat.cf
        • inventory/suse.cf
        • inventory/windows.cf
        • inventory/
        • lib/autorun.cf
        • lib/bundles.cf
        • lib/cfe_internal.cf
        • lib/cfe_internal_hub.cf
        • lib/cfengine_enterprise_hub_ha.cf
        • lib/commands.cf
        • lib/common.cf
        • lib/databases.cf
        • lib/edit_xml.cf
        • lib/event.cf
        • lib/examples.cf
        • lib/feature.cf
        • lib/files.cf
        • lib/guest_environments.cf
        • lib/monitor.cf
        • lib/packages.cf
        • lib/paths.cf
        • lib/processes.cf
        • lib/reports.cf
        • lib/services.cf
        • lib/stdlib.cf
        • lib/storage.cf
        • lib/testing.cf
        • lib/users.cf
        • lib/vcs.cf
        • lib/
        • modules/mustache/
        • modules/packages/vendored/
        • modules/packages/
        • modules/promises/cfengine.py
        • modules/promises/cfengine.sh
        • modules/promises/
        • modules/
        • services/autorun/
        • services/main.cf
        • services/
      • Macros
      • All promise and body types
    • Resources
      • FAQ
        • Why knowledge management?
        • Requesting a CFEngine Enterprise License
        • Uninstalling / reinstalling
        • Debugging slow queries
        • Enterprise report collection
        • Enterprise Report Filtering
        • Enterprise reporting database
        • Why does CFEngine install into /var/cfengine instead of following the FHS?
        • How do I find the public key for a given host
        • How do I fix trust after an IP change?
        • How do I fix undefined body errors?
        • How do I integrate custom policy?
        • Manual execution
        • Mustache templating
        • Agent output email
        • How can I tell what classes and variables are defined?
        • Unable to log into Mission Portal
        • Users
        • How do I pass a data type variable?
        • What is promise locking?
        • Why are some files inside masterfiles not being updated/distributed?
        • Why are remote agents not updating?
        • Bootstrapping
        • Tuning PostgreSQL
        • What did CFEngine do?
      • Additional topics
        • Agility
        • Application management
        • Build Deploy Manage Audit
        • Change management
        • Cloud computing
        • Content driven policy
        • DevOps
        • Distributed scheduling
        • File content
        • Hierarchies
        • Iteration (Loops)
        • ITIL
        • Modularity and orchestrating system policy
        • Using CFEngine with Open Nebula
        • Orchestration
        • Security
        • STIGs
        • Teamwork
      • External resources
      • Best practices
    • Docs homepage
    • Legal and licenses
    • Contact us
    • Last update on 25 Oct 2025