This package is an adapter that is meant to be used with the inmanta orchestrator: https://docs.inmanta.com
This module allows to manage files, on a unix host. It contains the following resources:
files::Directory: to manage a directory, its existence, permissions and ownership.files::TextFile: to manage a simple text file, its existence, content, permissions and ownership. This should not be used for big files, as the content of the file is embedded in the resource itself.files::HostFile: to manage hosts file entries (i.e./etc/hosts), but allowing the file to be managed by other tools. The resource makes sure to only modify the entries defined in its desired state and leave the rest untouched.files::JsonFileandfiles::SharedJsonFile: to manage json file entries. Similarly tofiles::HostFile, only change in the file what is present in the desired state. The file can then still be modified by other tools.files::SystemdUnitFile: an entity representing a unit file, which exposes it most useful properties directly in the model. After being exported, this resource becomes nothing more than a text file.files::Symlink: to manage a symlink, its existence and ownership.
The following example makes sure that the directory /example/folder/a exists, and creates a text file in it.
import mitogen
import files
import std
host = std::Host(
name="localhost",
os=std::linux,
via=mitogen::Local(),
)
dir = files::Directory(
host=host,
path="/example/folder/a",
# The directory that is managed is /example/folder/a, but the resource
# will also make sure that any of its parent directories exists as well
create_parents=true,
)
file = files::TextFile(
host=host,
path=f"{dir.path}/file.txt",
content="test",
# No need to explicitly add the dependency to the parent, the
# exporter takes care of adding it
# requires=dir,
)
Find more examples in the ´tests` folder of this module!