Skip to content

AutoPkgr is a free Mac app that makes it easy to install and configure AutoPkg.

License

Notifications You must be signed in to change notification settings

diskmakerx/autopkgr

 
 

Repository files navigation

AutoPkgr

autopkgr_logo.png

AutoPkgr is a free Mac app that makes it easy to install and configure AutoPkg.

AutoPkg is an awesomely powerful tool for automating OS X software packaging and distribution, but it requires its users to be comfortable with command-line tools and methods. If you're not yet comfortable with the command-line, or if you just want to get AutoPkg set up from scratch quickly and reliably, AutoPkgr is for you.

To get started, download the latest release, install and configure AutoPkgr, search for and add the recipes you need, and (optionally) integrate AutoPkgr with your software distribution tool. If you need help, check out the Troubleshooting section.

divider

divider

Features

AutoPkgr makes these tasks a piece of cake:

  • Installation of AutoPkg itself.
  • Installation of Git, which AutoPkg uses.
  • Discovery of and subscription to the repositories and recipes you need.
  • Automatic scheduled checks of the recipes you choose.
  • Email, Slack, or HipChat notifications when new software is packaged.
  • Ability to easily create and edit AutoPkg recipe overrides.
  • Easy access to common folders that AutoPkg admins need.
  • Basic integration of AutoPkg with popular software distribution frameworks like Munki, Casper Suite, HEAT LANrev, FileWave, and MacPatch.

divider

Installation

AutoPkgr requires Mac OS X 10.8 or higher. If you plan on integrating with Munki, Casper, or other tools, additional requirements may apply. (See the Integrations section for details.)

Download the latest release, and drag the AutoPkgr app to your Applications folder. Then launch it.

divider

Basic Usage

  1. Launch the AutoPkgr app.

  2. On first launch, you'll see the configuration window:

    Install

  3. Click the button to Install AutoPkg if it's not already installed.

  4. Click the button to Install Git if it's not already installed.

  5. Switch to the Repos & Recipes tab.

    Repos & Recipes

  6. Select the repositories you'd like to subscribe to. We recommend adding the "default" repo to get you started:

    Default repo

    You can also add repositories manually using the "Add a repo URL manually" field.

    Add a repo manually

  7. Select any recipes you wish to include in scheduled recipe runs.

    You can search for recipes using the "Search for a recipe on GitHub" field.

  8. Switch to the Schedule tab.

    Schedule

  9. Set the schedule for automatically running recipes. Many people like to set this for once per day.

    ⚠️   Selecting "Update all repos before each AutoPkg run" exposes you to some risk, and isn't generally recommended unless you unconditionally trust the contributors to the repos you subscribe to.

  10. Switch to the Notifications tab.

    Notifications

  11. Configure email, Slack, or HipChat notifications as desired.

That's it! AutoPkgr will now check for the latest app updates you specified, and when an update is available you'll receive a notification.

 

Anytime you'd like to make changes to AutoPkgr's configuration, click on AutoPkgr's icon in the Dock, or click on the AutoPkgr icon in the menu bar (Menu bar icon), and choose AutoPkgr Preferences...

You'll also find some useful shortcuts on the Folders & Integration tab, which will take you directly to several convenient AutoPkg folders. On that tab, you can also configure integration with Munki, Casper, and other software deployment systems (see below).

Folders & Integration

divider

Searching for Recipes

AutoPkgr can help you find recipes for the apps you want. In the Recipes & Repos tab, enter the name of the app into the "Search for a recipe on GitHub" field, and click Search.

Search for a Recipe

From the list of results, select your desired recipe. If the repo is not already added (as shown by the green indicator), then click Add Repo.

Add a Repo

Click Close to return to the recipe list. Then you should see the newly-added recipe in your available recipes list. Click the checkbox next to the recipe you want, and it will be included in future scheduled AutoPkg runs.

Add the Recipe

Don't see a recipe for an app you use? Use Recipe Robot or write one manually!

divider

Running individual recipes

If you want to run a single recipe once, simply right-click on a recipe and choose Run This Recipe Only.

Running individual recipes

If the recipe you're running is a .munki recipe, MakeCatalogs.munki will also run.

divider

Creating/Editing Recipe Overrides

Recipe overrides allow you to tailor recipes' input variables to your organization's needs.

We've tried to simplify the process of creating and editing AutoPkg recipe overrides. Just right-click on a recipe in the list, and you'll see options for creating an override or editing an existing override.

To select which text editor to use when editing overrides, go to Folders & Integration > Configure AutoPkg > Recipe/Override Editor.

divider

Customizing notifications

To avoid unwanted notifications, you can customize which AutoPkg events trigger a notification to be sent. To do this, go to the Notifications tab and click the Customize... button next to Choose which actions trigger notification.

You can choose to be notified on all events, or you can select a subset of events you care about and ignore the rest.

When you're done, click Close.

divider

Using a Proxy

If your network uses a proxy, you may need to navigate to the Folders & Integration tab and click on the Configure AutoPkg button. Adjust the proxy settings as necessary.

proxy

divider

Integrations

AutoPkgr makes it as easy as possible to integrate with these software distribution systems:

Integration with Munki

💡   Note: Requires the Munki tools to be installed on the Mac running AutoPkgr.

To configure AutoPkgr to add updates directly into your Munki repository, follow these steps:

  1. Click on the Folders & Integration tab.

  2. If Munki tools are not already installed, click on the Install Munki tools button. Enter your password if prompted.

  3. Click on the Configure Munki tools... button, click Choose, and browse to your munki_repo (which can be on a mounted volume).

    Munki repo

  4. Click Save and Close.

You'll also want to make sure you have .munki recipes selected for each app you want to import. Once the new versions of apps appear in your Munki repo, you can add them to the appropriate catalogs and manifests to deploy them.

Integration with Casper

💡   Note: Requires Casper version 9 or newer.

To configure AutoPkgr to create Self Service policies in Casper for new app updates, follow these steps:

  1. Create a static computer group on your JSS called Testing. Add one or more test computers to the group.

  2. Create an account on your JSS with Create, Read, and Update access to the following objects:

    • Categories
    • Computer Extension Attributes
    • File Share Distribution Points (only needs Read access)
    • Packages
    • Policies
    • Scripts
    • Smart Computer Groups
    • Static Computer Groups
  3. Open AutoPkgr and go to the Folders & Integration tab.

  4. Click the Install JSSImporter button. Enter your password if prompted.

  5. Click on Configure JSSImporter.

  6. Enter your JSS URL, API username, and API password. Then click Connect.

    Casper Settings

  7. When prompted, enter the read/write password for each distribution point.

  8. Click Save and Close.

You'll also want to make sure you have a few .jss recipes selected. AutoPkgr will automatically add the "official" jss-recipes repo so you'll have a few to choose from right away.

When a .jss recipe runs, the package is uploaded to your distribution points, a Self Service policy is created and scoped to a new smart group. As a result, computers in the Testing group with less than the latest version of the app should now be able to install the latest version through Self Service.

For detailed information on JSS recipe behavior, check out the README for jss-recipes, and for some examples of advanced worfklows, see Auto Update Magic.

Integration with HEAT LANrev

⚠️   LANrev integration is still in beta. We welcome your feedback.

⚠️   If you previously used Tom Burgin's AbsoluteManageExport processor and .absolute recipes, please see the LANrevImporter documentation for information about how to transition to LANrevImporter.

💡   Notes and requirements for LANrev integration:

  • LANrev version 6.5 or newer is required.
  • The LANrev Admin app should be installed in your Applications folder.
  • Launch LANrev Admin and connect the app to your LANrev server.
  • In order to run .lanrev recipes, your Mac needs to be logged in and the LANrev Admin app needs to be running.

To configure AutoPkgr to add updates directly into your LANrev server, follow these steps:

  1. Click on the Folders & Integration tab.

  2. Click on the Install LANrevImporter button. Enter your password when prompted.

  3. Click on the Configure LANrevImporter... button. Select the Enable External SD Package Upload option if desired.

    LANrev Settings

  4. Click Save and Close.

You'll also want to make sure you have a few .lanrev recipes selected. There is no official repository for LANrev recipes yet, but if you add the seansgm-recipes repository, you'll see a few to get you started.

Integration with MacPatch

⚠️   MacPatch integration is still in beta. We welcome your feedback.

💡   Note: Requires you to have the default recipe repo added.

Default repo

To configure AutoPkgr to add updates directly into your MacPatch server, follow these steps:

  1. Click on the Folders & Integration tab.

  2. Click on the Install MacPatchImporter button. Enter your password when prompted.

  3. Click on the Configure MacPatchImporter... button. Enter the URL, username, and password for your MacPatch server.

    MacPatch Settings

  4. Click Save and Close.

divider

Integration with FileWave

⚠️   FileWave integration is still in beta. We welcome your feedback.

💡   Notes and requirements for FileWave integration:

  • AutoPkg version 0.5.0 or newer is required.
  • FileWave version 10.0 or newer is required.
  • The FileWave Admin app should be installed in your Applications folder.

To configure AutoPkgr to add updates directly into your FileWave server, follow these steps:

  1. Click on the Folders & Integration tab.

  2. Click on the Install FileWaveImporter button. Enter your password when prompted.

  3. Click on the Configure FileWaveImporter... button.

  4. Enter the hostname, port, username, and password for your FileWave server, and click Verify.

    FileWave Settings

  5. If verification succeeds, click Save and Close.

divider

Troubleshooting

Step 1: Check for simple errors

  • Missing parent recipes If the recipe you're trying to run has a ⚠️ icon next to it, the most likely problem is that its parent recipe is missing.

    Recipe missing parent

    Right-click on the recipe to view the identifier of the parent recipe.

    View parent recipe identifier

    You don't need to add the parent recipe itself to your list, but you do need to make sure that the repository that the parent recipe belongs to is checked in the repo list.

  • Out of date components Quit and relaunch AutoPkgr to check for new versions of installed components, including AutoPkg, Git, and AutoPkgr itself. We recommend updating to the latest version of these tools as a first step when troubleshooting.

  • Temporarily broken recipes Because software manufacturers frequently change their feeds, recipes that used to work sometimes stop working. Wait a day or so, then update your repos and try running the recipe again. Also see the troubleshooting steps here.

  • AutoPkg is already running If you get an error that says "A scheduled AutoPkg run may be running in the background," try running this command in the Terminal:

    ps ax | grep python | grep autopkg
    

    This should reveal the process information for active AutoPkg runs. If it's appropriate to do so, you can then terminate the process(es) by using kill or killall.

Step 2: Is it really AutoPkgr?

If you've eliminated the simple errors above, but AutoPkgr still doesn't do what you expect, the next step is to run your recipes directly using autopkg in Terminal. The following command has been helpful for us when troubleshooting. (Triple-click to select the entire line for copying.)

/usr/bin/python /usr/local/bin/autopkg run --recipe-list ~/Library/Application\ Support/AutoPkgr/recipe_list.txt --report-plist /tmp/autopkg-report.xml

If the issue repeats itself there, it's likely that the problem is with an AutoPkg recipe or repository, not with AutoPkgr. See if you can see which recipe is failing based on the output of the command above. (Information on troubleshooting individual AutoPkg recipes is available on the AutoPkg wiki.)

For problems with email notifications, try sending an email using the same SMTP settings in another email client app.

Step 3: Check the logs

If you've determined the issue is with AutoPkgr and not a specific recipe or repo, you may find it useful to enable AutoPkgr's verbose logging feature. To do that, click the AutoPkgr icon in the menu bar (Menu bar icon). Then select Verbose Logs.

The simplest way to view the logs is to filter for "AutoPkgr" in the Console app on your Mac.

Check the logs

Step 4: Reach out for help

If you're still stuck, you may want to post a message (and relevant sections of the Console logs, after removing any sensitive information) to our Google Group. And if it's a reproducible bug, please do submit an issue on GitHub. We do our best to investigate bug reports and release fixes.

We also welcome feature requests on GitHub! Some of our best features have come from community suggestions.

divider

Credits

AutoPkgr was created at the Linde Group in Emeryville, California. If you're a talented Mac admin looking for a job in the Bay Area, check out our job listings. We've got a wonderful team of people and fantastic clients.

James Barclay, Elliot Jordan, and Josh Senick originally created AutoPkgr in June 2014, and ongoing development is led by Eldon Ahrold, Elliot Jordan, and James Barclay.

Briefcase icon from FontAwesome.

Linde Group

About

AutoPkgr is a free Mac app that makes it easy to install and configure AutoPkg.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Objective-C 96.7%
  • HTML 1.8%
  • Python 1.3%
  • Other 0.2%