Having a list of software that is allowed to be installed on a host is a strategy to prevent and fix security gaps and maintain compliance with operational guidelines. This zero-trust methodology ensures that only explicitly permitted applications are allowed to be present on a host unlike package block-listing which enumerates an explicit list of software that is not allowed to be present. In fact, with a software allow-list, you are essentially block-listing everything except the software you allow.
The new packages-allowlist module on CFEngine Build can help you facilitate this.
The packages-allowlist
module targets the platforms default package manager and provides an inventory of packages installed that are not in the allow-list (as defined by the packages_allowlist:state.allowed
list variable) by default.
data:image/s3,"s3://crabby-images/70874/70874eb15cf20a6c2471003bbbdb9ae411b86322" alt="packages-allowlist module with input data configuring allowed list of packages"
Any packages found installed that are not in the allow-list are inventoried as Packages installed not in allow list
.
data:image/s3,"s3://crabby-images/32f76/32f7638725f06f5780ed2c45da0b25e342bb9983" alt="Inventory showing a package not in the allowed list of software packages"
This inventory can be used to build alerts and compliance checks to quickly notify stakeholders of non-compliance.
data:image/s3,"s3://crabby-images/caa72/caa724d317344914a20b5ae21081b98a9956b54a" alt="My inventory screenshot"
By default packages_allowlist:state.enforcement
is set to disabled
. While packages_allowlist:state.enforcement
is not enabled
warnings are emitted for each package that is not found in packages_allowlist:state.allowed
.
data:image/s3,"s3://crabby-images/fb1da/fb1daf69f75ed9d83a5335a8a734682f1b30c513" alt="Screenshot showing behavior when package not in allowlist is found and enforcement is not enabled"
When the variable packages_allowlist:state.enforcement
has a value of enabled
these packages will be automatically removed.
data:image/s3,"s3://crabby-images/4eff7/4eff7b8d5cb1e9271d5c2f829efeb7c0c70ee41c" alt="Screenshot showing behavior when package not in allowlist is found and enforcement is enabled"
data:image/s3,"s3://crabby-images/d639e/d639ec54754e7fed69498b532982ba65c358e069" alt="Screenshot showing Changes report highlighting package removal in Mission Portal"
Try out the module and let us know what you think on GitHub Discussions or on the help mailing list.