Human-oriented CLI for interacting with CFEngine tools
Project description
CFEngine command line interface (CLI)
A CLI for humans to interact with CFEngine, enabling downloading and installing packages, building policy sets, deploying, and enforcing policy.
It is practically a wrapper around our other tools, like cf-agent, cf-hub, cf-remote and cfbs.
Warning: This is an early version. Things might be missing or changed. Proceed with caution and excitement.
Installation
Install using pip:
pip install cfengine
Usage
Run the CFEngine agent - evaluate and enforce policy
cfengine run
CFEngine CLI help
cfengine help
Print CFEngine CLI version
cfengine version
Automatically format source code
cfengine format
Check for errors in source code
cfengine lint
You can also specify filenames or folders;
cfengine lint main.cf
When it finds a mistake, it points out where the problem is like this;
"Hello, CFEngine"
ifvarclass => "cfengine";
^--------^
Deprecation: Use 'if' instead of 'ifvarclass' at main.cf:5:7
FAIL: main.cf (1 error)
Failure, 1 error in total.
Note that since we use a different parser than cf-agent / cf-promises, they are not 100% in sync.
cf-agent could point out something as a syntax error, while cfengine lint does not and vice versa.
We aim to make the tree-sitter parser (used in this tool) more strict in general, so that when cfengine lint is happy with your policy, cf-agent will also accept it.
(But the opposite is not a goal, that cfengine lint must accept any policy cf-agent would find acceptable).
Build a policy set
cfengine build
(This is equivalent to running cfbs build).
Supported platforms and versions
This tool will only support a limited number of platforms, it is not intended to run everywhere CFEngine runs. Currently we are targeting:
- Officially supported versions of macOS, Ubuntu, and Fedora.
- Officially supported versions of Python.
It is not intended to be installed on all hosts in your infrastructure. CFEngine itself supports a wide range of platforms, but this tool is intended to run on your laptop, your workstation, or the hub in your infrastructure, not all the other hosts.
Backwards compatibility
This CLI is entirely intended for humans. If you put it into scripts and automation, expect it to break in the future. In order to make the user experience better, we might add, change, or remove commands. We will also be experimenting with different types of interactive prompts and input.
Development, maintenance, contributions, and releases
Looking for more information related to contributing code, releasing new versions or otherwise maintaining the CFEngine CLI? Please see the HACKING.md file.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cfengine-0.13.0.tar.gz.
File metadata
- Download URL: cfengine-0.13.0.tar.gz
- Upload date:
- Size: 116.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1b8ff0a1845abf7ec68844e1bcb67baa0326f9e2cf8ce905a0aae57f22a85fac
|
|
| MD5 |
cad48b75f649af65f09f9d8c76a8fbb1
|
|
| BLAKE2b-256 |
e5ade69c23a61998d36c317091efa2545fe04ec8e89fe13df51237c107ac5859
|
Provenance
The following attestation bundles were made for cfengine-0.13.0.tar.gz:
Publisher:
pypi-publish.yml on cfengine/cfengine-cli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cfengine-0.13.0.tar.gz -
Subject digest:
1b8ff0a1845abf7ec68844e1bcb67baa0326f9e2cf8ce905a0aae57f22a85fac - Sigstore transparency entry: 1247032528
- Sigstore integration time:
-
Permalink:
cfengine/cfengine-cli@d90455b74d948d9c2d3902ed81ddc046cebcd3b7 -
Branch / Tag:
refs/tags/0.13.0 - Owner: https://github.com/cfengine
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-publish.yml@d90455b74d948d9c2d3902ed81ddc046cebcd3b7 -
Trigger Event:
release
-
Statement type:
File details
Details for the file cfengine-0.13.0-py3-none-any.whl.
File metadata
- Download URL: cfengine-0.13.0-py3-none-any.whl
- Upload date:
- Size: 61.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3350eca159aebfa730874a21965e99140a576b053076a217bbaafb0b4b7c4783
|
|
| MD5 |
ee3573e781ef555f32f9179067a78af1
|
|
| BLAKE2b-256 |
d0e26910f5d0476b995a7371f713d45d236afc12d47d80555ed0402e10952088
|
Provenance
The following attestation bundles were made for cfengine-0.13.0-py3-none-any.whl:
Publisher:
pypi-publish.yml on cfengine/cfengine-cli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cfengine-0.13.0-py3-none-any.whl -
Subject digest:
3350eca159aebfa730874a21965e99140a576b053076a217bbaafb0b4b7c4783 - Sigstore transparency entry: 1247032530
- Sigstore integration time:
-
Permalink:
cfengine/cfengine-cli@d90455b74d948d9c2d3902ed81ddc046cebcd3b7 -
Branch / Tag:
refs/tags/0.13.0 - Owner: https://github.com/cfengine
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-publish.yml@d90455b74d948d9c2d3902ed81ddc046cebcd3b7 -
Trigger Event:
release
-
Statement type: