The Bouncer
Convenient Web Requests
The second part of the alarm pipeline is shown in Listing 2; the REST request sent to the Pushover API server requires two tokens (lines 12 and 13), which users receive when registering with the Pushover service. The trial period lasts for four weeks and allows free access; if you like what you see, you can then buy a license for $5, which covers a single platform: iOS, Android, or the desktop client.
Registered users will find the token assigned to the user
key in the Pushover dashboard overview in Figure 4. The token labeled token
, on the other hand, identifies the app (Figure 5) to the Pushover service; in this case, it is the Python script in Listing 2, which I registered with Pushover under the name Snapshot.
Listing 2
pushover
For a successful REST request with Python's requests
library, you also need the message
parameter with the message text for the post()
method in line 9 to contact Pushover. In typical Python style, the library throws exceptions that abort the program in case of errors if they're not processed and outputs a stack trace that will hopefully help you solve the problem.
The Python requests
library keeps its promise of being a self-proclaimed "HTTP for Humans." At least it is more carefully thought out than urllib
and urllib2
, which you might remember I have complained about before.
Line 6 in Listing 2 retrieves the text sent from the first part of the pipeline from standard input and truncates it with the usual syntax for array slices in Python – [:1024]
– to the maximum length of 1,024 characters allowed by Pushover. The if
construct in lines 8-15 then uses the regular expression \S
to check whether the message contains printable characters and terminates empty runs without further ado.
Friend Cron
All you have to do now is set up a cron job that calls the pipeline about every five minutes and finds the user's home directory and the writable data
directory therein for storing the flag file:
*/5 * * * * /path/authwatch | /path/pushover
The Pushover service distributes any messages sent to all devices registered by the user, so it may happen that a failed login attempt triggers a whole explosion of notifications if several mobile devices in the room are actively connected. At least this only counts as one message, though, in the usage constraints, of which users are allowed 7,500 per month on the all-inclusive tier.
Mike Schilli
Mike Schilli works as a software engineer in the San Francisco Bay area of California. In his column, launched back in 1997, he focuses on short projects in Perl and various other languages. You can contact Mike at mailto:mschilli@perlmeister.com.
Infos
- "WiFi Connect Messages" by Mike Schilli, Linux Pro Magazine, issue 186, May 2016, p. 64, http://www.linux-magazine.com/Issues/2016/186/Perl-WiFi-Connect-Messages
- Pushover login: https://client.pushover.net
- Pygtail: https://github.com/bgreenlee/pygtail
- Listings for this article: ftp://ftp.linux-magazine.com/pub/listings/linux-magazine.com/200
« Previous 1 2
Buy this article as PDF
(incl. VAT)
Buy Linux Magazine
Subscribe to our Linux Newsletters
Find Linux and Open Source Jobs
Subscribe to our ADMIN Newsletters
Support Our Work
Linux Magazine content is made possible with support from readers like you. Please consider contributing when you’ve found an article to be beneficial.
News
-
Linux Servers Targeted by Akira Ransomware
A group of bad actors who have already extorted $42 million have their sights set on the Linux platform.
-
TUXEDO Computers Unveils Linux Laptop Featuring AMD Ryzen CPU
This latest release is the first laptop to include the new CPU from Ryzen and Linux preinstalled.
-
XZ Gets the All-Clear
The back door xz vulnerability has been officially reverted for Fedora 40 and versions 38 and 39 were never affected.
-
Canonical Collaborates with Qualcomm on New Venture
This new joint effort is geared toward bringing Ubuntu and Ubuntu Core to Qualcomm-powered devices.
-
Kodi 21.0 Open-Source Entertainment Hub Released
After a year of development, the award-winning Kodi cross-platform, media center software is now available with many new additions and improvements.
-
Linux Usage Increases in Two Key Areas
If market share is your thing, you'll be happy to know that Linux is on the rise in two areas that, if they keep climbing, could have serious meaning for Linux's future.
-
Vulnerability Discovered in xz Libraries
An urgent alert for Fedora 40 has been posted and users should pay attention.
-
Canonical Bumps LTS Support to 12 years
If you're worried that your Ubuntu LTS release won't be supported long enough to last, Canonical has a surprise for you in the form of 12 years of security coverage.
-
Fedora 40 Beta Released Soon
With the official release of Fedora 40 coming in April, it's almost time to download the beta and see what's new.
-
New Pentesting Distribution to Compete with Kali Linux
SnoopGod is now available for your testing needs