Hello 2025! Here's pyinfra 3.2 - with another incredible round of contributions from the community, THANK YOU ALL. New stuff:
- Add total counts to results summary (@NichtJens)
- Enable passing extra data via
local.include
(@TimothyWillard) - Validate inventory files and display warnings for unexpected variables (@simonhammes)
New operations/facts:
- Add
pipx
operations (packages
,upgrade_all
,ensure_path
) facts (PipxPackages
,PipxEnvironment
) and operations (@maisim) - Add
server.OsRelease
fact (@wowi42) - Add
podman.PodmanSystemInfo
andpodman.PodmanPs
facts (@bauen1) - Add many extra arguments (including generic args) to
files.FindFiles*
facts (@JakkuSakura) - Add
system
argument togit.config
operation (@Pirols) - Add
psql_database
argument to postgres operations & facts (@hamishfagg) - Add
files.Sha384File
fact andsha384sum
argument tofiles.download
operation (@simonhammes) - Add
apt.SimulateOperationWillChange
fact (@bauen1) - Detect changes in
apt.upgrade
andapt.dist_upgrade
operations (@bauen1) - Add
fibootmgr.EFIBootMgr
fact (@bauen1) - Add opkg facts and operations (@morrison12)
Fixes:
- Multiple fixes for
server.crontab
operation and facts (@JakkuSakura) - Correctly handle
latest
argument with requirements file inpip.packages
operation (@amiraliakbari) - Fix regex used to parse installed apk packages (@simonhammes)
- Fix SSH connector overwriting known hosts files (@vo452)
Docs/internal tweaks:
- Add type annotations for many more operations (@simonhammes)
- Add typos CI checking to replace flake8-spellcheck (@simonhammes)
- Bump CI actions and dependencies (@simonhammes)
- Require JSON tests to include all arguments
- Remove unused
configparser
dependency (@bkmgit) - Many small documentation fixes/tweaks
- Improve errors with 2.x style
@decorator
(vs@decorator()
) functions - Document adding custom connectors (@simonhammes)
- Add basic API example to docs (@pirate)
- Fix sphinx warnings (@simonhammes)
- Fix force & pull arguments in
git.worktree
operation - Fix
server.reboot
reconnection (@wackou) - Fix chroot/local connector non-utf file gets (@evoldstad)
- Fix
AptSources
fact to parse components in order & with digits (@rsfzi)
Here's pyinfra 3.1 - a release primarily driven by contributors new and old - a HUGE THANK YOU to all of you who dedicate time to work on pushing pyinfra forward. New stuff:
- Add
zfs
operations (dataset
,snapshot
,volume
,filesystem
) facts (Pools
,Datasets
,Filesystems
,Snapshots
,Volumes
) (@taliaferro) - Add
flatpak
operations (packages
) and facts (FlatpakPackage
,FlatpakPackages
) (@JustScreaMy) - Add
jinja_env_kwargs
argument tofiles.template
operation (@DonDebonair) - Add using dictionaries as
@terraform
output (map from group -> hosts) - Add default
@terraform
output key -pyinfra_inventory.value
, promote connector to beta - Add support for multiple keys in each
server.authorized_keys
file (@matthijskooijman) - Add print all dependency versions with
--support
flag (@kytta)
Fixes:
- Fix when
ssh_hostname
is set as override data, don't do inventory hostname check - Fix
apt.AptSources
parsing special characters (@CondensedTea) - Fix
server.reboot
connection detection (@bauen1 + @lemmi) - Fix systemd flagging of sockets running (@bauen1)
- Fix mysql dump quoting (@simonhammes)
- Fix tilde expansion in files facts (@simonhammes)
- Fix host lookup check with SSH alias config (@simonhammes)
- Fix crontab comparison (@andrew-d)
Docs/internal tweaks:
- Improve operations documentation (@bauen1)
- Default to local machine if
user_name
set in systecmt (@bauen1) - Improve efficiency of Docker operations (@apecnascimento)
- Shallow copy
host.data
data to mutation
- Fix
OperationMeta.did_change
: this is now a function as originally designed - Add quick test for
host.when
context manager - Remove extra detected changes note when not relevant
- Switch to
command -v
notwhich
inserver.Which
fact (@lemmi) - Fix detection of xbps in
server.packages
operation (@romain-dartigues) - Fix argument typo in operations doc (@scoufman)
- Add expanded note about detected changes + hidden side effects during execution
- Fix missing global arguments in group data files
- Fix
--group-data
CLI argument behaviour - Remove unused/dead
--quiet
flag
Welcome to pyinfra v3! This version is the biggest overhaul of pyinfra since it was created back in 2015. Most v2 deployment code should be automatically compatible, but as always be aware. Major changes:
pyinfra now executes operations at runtime, rather than pre-generating commands. Although the change isn't noticeable this fixes an entire class of bugs and confusion. See the limitations section in the v2 docs. All of those issues are now a thing of the past.
This represents a huge overhaul of pyinfra's internals and should be a huge improvement for users.
Care has been taken to reduce the overhead of this change which still supports the same diffs and change proposal mechanism.
The pyinfra CLI will now prompt (instead of ignore, or immediately exit) when problems are encountered, allowing the user to choose to continue. Additionally an approval step is added before executing changes (this can be skipped with -y
or setting the PYINFRA_YES
environment variable).
v3 of pyinfra includes for the first time a (mostly) typed internal API with proper support for IDE linting. There's a whole new connectors API that provides a framework for building new connectors.
- Rename
_use_sudo_password
argument to_sudo_password
- Remove
winrm
connector andwindows*
operations/facts, moving topyinfra-windows
- The deploy decorator must now be called, ie used as
@deploy()
, and is now typed - Remove broken Ansible inventory connector
- Add
docker.container
,docker.image
,docker.volume
,docker.network
&docker.prune
operations (@apecnascimento) - Add
runit.service
operation andRunitStatus
fact (@lemmi) - Add
TmpDir
fact - Add
services
argument to systemd facts for filtering - Add type hints for all the operations (@stone-w4tch3r)
- Lowercase pip packages properly (PEP-0426)
- Rename
postgresql
->postgres
operations & facts (old ones still work) - Improve IP/MAC parsing in
NetworkDevices
fact (@sudoBash418) - Enable getting
Home
fact for other users (@matthijskooijman) - Use users correct home directory in
server.user_authorized_keys
operation (@matthijskooijman) - Fix
destination
/not_destination
arguments iniptables.rule
operation - Fix remote dirs when executing from Windows in
files.sync
operation (@Renerick) - Fix quoting of systemd unit names (@martenlienen)
- Add new
_if
global argument to control operation execution at runtime - Add
--debug-all
flag to set debug logging for all packages - Retry SSH connections on failure (configurable, see SSH connector) (@fwiesel)
- Documentation typo fixes (@szepeviktor, @sudoBash418)
- Fix handling of binary files in Docker connector (@matthijskooijman)
- Add
will_change
attribute anddid_change
context manager toOperationMeta
- Replace use of
pkg_resources
withimportlib.metadata
(@diazona) - Fix identifying Python inventory files as modules (@martenlienen)
- Fix typed arguments order (@cdleonard)
- Check that fact commands don't take global arguments (@martenlienen)