Written by @haircut
Matthew Warren is an IT engineer working in the transportation industry.
Although Slack has seemingly taken over the world of workplace chat, my organization is a G Suite shop and we use Hangouts Chat for a majority of our internal communication. It’s included as a “core” G Suite app, so why not use the product we already have, right?
I wanted a way to post notifications to Hangsouts Chat rooms when autopkg downloads new software, or makes changes to our Jamf Pro server via JSSImporter. No solution existed. Building on the excellent Slack-centric work of both Graham R Pugh and Rich Trouton, I’ve made two different autopkg postprocessors to send autopkg notifications to Google Hangouts Chat.
HangoutsChatNotifier- simple notifications
If you’d just like to know when your automated autopkg run downloads new
HangoutsChatNotifier will send a simple note to a Hangouts
HangoutsChatJSSNotifier- going deeper with
If you’re using JSSImporter
to automate the process of adding the software autopkg downloads to your
HangoutsChatJSSNotifier will send more detailed messages to a
Hangouts Chat room.
Both postprocessors leverage the existing data provided during an autopkg run to send data to a Hangouts Chat incoming webhook.
To set these up on your own G Suite domain, you’ll need:
In Hangouts Chat, open the room you’d like to notify, then click the room’s name near to top of the screen.
Click Configure webhooks. Enter a name for the incoming webhook – I just use “autopkg” – then click Save.
You’ll see a long URL displayed representing the API endpoint we can use to send messages to this room. Copy that URL and save it for later.
Whichever you like!
HangoutsChatNotifier sends simple messages to inform you when your
autopkg workflow has downloaded new software. The quick notifications
might be useful to send to your desktop support team Hangouts Chat room,
or your QA group.
If you’re using
JSSImporter as part of your autopkg workflow, you may
find the expanded detail provided by
JSSImporter is beyond the scope of this article – but if you’re
HangoutsChatJSSNotifier will help you send notifications
to Hangouts Chat.
You have two options to include the Hangouts Chat postprocessors in your autopkg runs.
The simplest method is to include the
--post flag when running autopkg
at the command line.
Specify the postprocessor name
and provide a
--key in the form
--key hangoutschat_webhook_url="<incoming webhook url>".
<incoming webhook url> with the URL you noted earlier after
creating an incoming webhook in your Hangouts Chat room.
A complete command might look like:
autopkg run MyRecipe.recipe \ --post "com.github.haircut.HangoutsChatNotifier/HangoutsChatNotifier" \ --key hangoutschat_webhook_url="https://chat.googleapis.com/v1/spaces/XXX/messages?key=XXX-XXX&token=XXX-XXX"
Just like the simple notifier, add a
--post flag to your autopkg run
and a `
--key hangoutschatjss_webhook_url="<incoming webhook url>".
This example might look like:
autopkg run MyRecipe.recipe \ --post "com.github.haircut.HangoutsChatJSSNotifier/HangoutsChatJSSNotifier" \ --key hangoutschatjss_webhook_url="https://chat.googleapis.com/v1/spaces/XXX/messages?key=XXX-XXX&token=XXX-XXX"
If you use a text file list of multiple recipes the postprocessors are compatible and will send a Hangouts Chat message after each recipe runs.
autopkg run --recipe-list /path/to/recipe_list.txt \ --post "com.github.haircut.HangoutsChatJSSNotifier/HangoutsChatJSSNotifier" \ --key hangoutschatjss_webhook_url="https://chat.googleapis.com/v1/spaces/XXX/messages?key=XXX-XXX&token=XXX-XXX"
My preferred method of running multiple autopkg recipes is using a property list (plist). A plist recipe list lets you set up declarative and robust autopkg configurations that would otherwise require a messy string of command line arguments.
To include the Hangouts Chat postprocessor, add it as an array item under
postprocessors key. Then, add your incoming webhook url as a string
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> <plist version="1.0"> <dict> <key>recipes</key> <array> <string>MyRecipe.recipe</string> <string>AnotherRecipe.recipe</string> <string>RadicalRecipe.recipe</string> </array> <key>hangoutschat_webhook_url</key> <string>https://chat.googleapis.com/v1/spaces/XXX/messages?key=XXX-XXX&token=XXX-XXX</string> <key>postprocessors</key> <array> <string>com.github.haircut.HangoutsChatNotifier/HangoutsChatNotifier</string> </array> </dict> </plist>
Important! Hangouts Chat incoming webhook URLs
include an ampersand (
&) in the query parameters, which
is an illegal character within an XML
element. You must replace the ampersand with its
& when including the incoming
webhook URL in a property list file – otherwise the postprocessor
will fail to send a notification.
Now you can run your recipe list and send Hangouts Chat notifications using a much less cumbersome command:
autopkg run --recipe-list /path/to/recipe_list.plist
The namespace for each postprocessor is distinct, so you can use both
simultaneously during a single autopkg run. For example, you might like
to send your helpdesk a brief notification that new software is available
HangoutsChatNotifier, and your engineering team managing Jamf Pro
a more detailed note showing the changes made to your JSS.
For this example, you’d create one incoming webhook in your “helpdesk”
Hangouts Chat room and set its URL as the
key. Create a second incoming webhook in your “Jamf Pro” Hangouts Chat
room and set that URL as the
hangoutschatjss_webhook_url. Add both
postprocessors to your autpkg run – done!
If you have need to customize the formatting or content of the Hangouts Chat notifications, you can fork my postprocessors found at autopkg/haircut-recipes/PostProcessor. Google has great documentation around their message formats.
Now go forth and notify your teams!