Cleans out old Munki packages
- Why does OldMunkiPackages exist?
- Shouldn't it be OldMunkiItems and not OldMunkiPackages?
- How do you install OMP?
- Install .pkg file
- "Install" OMP manually
- Configure where to dump
- Configure protected packages
- How do you use OMP?
- What are the requirements for OMP?
- Why isn't OMP on a schedule?
- How does OMP work?
- What does OMP do with older packages that aren't in the same catalogs as the newer packages?
- How do I make sure one particular old version of a package never gets removed?
- Acknowledgements
Like a lot of open source software, this is useful to the author (me). Others may find it useful, too, which is why I'm sharing it, but ultimately I created it to cull old packages from the Munki server I maintain. If you find yourself doing that a lot, too, you may find this useful.
Even with a GUI tool like MunkiAdmin, the catalog can get unwieldy and take a while to scroll through if you have a lot of old software packages.
There are other great tools and tutorials (see below) that do similar things but not exactly what I wanted, which is just a straight clean-out of old packages. I also wanted to learn a little more Python, so this was a good exercise to undertake for that.
Spruce is a fairly sophisticated tool that does way more than I want (pretty cool features, though), and then there's an interactive shell script that helps to get old things out.
In August 2016, Greg Neagle also created repoclean as included in the Munki client code. Deletes instead of moves old stuff. Great tool if that's what you want to do.
I wanted to keep OMP (Old Munki Packages) fairly simple--just run with no arguments and automatically dump the old packages and pkginfo files.
Yes, it should. My bad. Not everything in a Munki repository is a .pkg. Sometimes it's an .app. Sometimes it's a nopkg.
Head over to the releases page to get the latest pre-packaged release (unsigned).
You can also use Munki-Pkg to build the package yourself, especially if there are any tweaks you want to make before packaging it.
If you would like the dumped files to go somewhere other than your trash, modify the <string></string> part to be <string>/Path/To/Where/You/Want/Files/Dumped</string>, and then put the com.github.aysiu.omp.plist file in the /Users/username/Library/Preferences folder of the username you're going to run OMP under. Otherwise, OMP will just default to using the logged-in user's trash as the dump folder.
You can also use a command like defaults write com.github.aysiu.omp dump_location "/Path/To/Where/You/Want/Files/Dumped"
If you would like to add more protected packages (the sample .plist file includes Office2011_update version 14.1.0 by default), you can do so by editing the .plist directly or by using a command like defaults write com.github.aysiu.omp protected_packages -array-add '{name="Office2011_update"; version="14.0.1";}'
OMP will also look for your repo path in ~/Library/Preferences/com.googlecode.munki.munkiimport.plist, which you create when you run the /usr/local/munki/munkiimport --configure
command the first time you set up Munki.
You can just call it manually:
/usr/local/omp/OldMunkiPackages.py
If you want to integrate it into your CI/CD processes, just treat it as you would any other script.
Logs (errors or information) will go to ~/Library/Logs/omp.log
I've tested it only on macOS (Catalina). In theory, it should work on older Macs, but it relies on Munki's embedded Python being installed. The way the script is written (referencing .plist files in ~/Library/Preferences) means it won't work for Windows or Linux.
The user who runs the script must have full read/write permissions on the Munki repository, as well as the destination (her own trash, or whatever folder she picks to move the old packages to).
The script isn't that destructive (rather than straight-out deleting the packages, it just moves them to a new location, even if that new location is the trash). Nevertheless, I would rather leave it up to the user to schedule (or run manually).
You're welcome to look at the code, but in plain English, it basically works this way:
- Loop through the pkgsinfo folder (and subfolders) in the Munki repo.
- For each pkgsinfo, check to see if it exists in a list of packages to keep. If it doesn't, add it. If it does, and it's a newer version than what's already in there, move the older one to a list of packages to remove, and then put the newer version in the list of packages to keep.
- Loop through the packages (both pkgsinfo and pkgs) to remove and move them to the new location.
- If any files have been dumped, run makecatalogs if it exists (it should).
OMP will check the catalogs a package belongs to, sort them (so testing, production and production, testing will be comparable), and compare them. So only if the exact catalogs match will the old one be dumped. This works well for situations like an older package being in testing and production, and a newer package being in only testing. In that case, you don't want to ditch the older package yet (until you've had a chance to test the newer one).
If you have some packages going through development, testing, production while other packages go through only testing, production, that's fine... as long as each package of the same name goes through the same catalog track. In other words, if CustomForYourOrg goes through development, testing, production and has two versions, the older version will be ditched if both the older and newer versions have development, testing, production as their catalogs. But you could also have MozillaFirefox go through only testing, production, and OMP will work fine to get rid of all the old Firefoxes, as long as they all have testing, production as their catalogs.
Add the name and version to the protected packages array in the .plist preferences file.
OMP also will not remove older versions of packages (even in the same catalogs) if the older version has a different minimum OS, so that may be one way around it if you want to keep older versions. For example, you may have a version of one package that goes through 10.10 and another that goes 10.11 and up. If you remove the 10.10 package, then the 10.10 users won't have access to any version of that package.
Thanks to Joseph Chilcote for some Python logging code.