A utility for mailgun's API to send emails regarding the SSH successful login
Linux-PAM short for Pluggable Authentication Module is the core of user's dynamic authentication support for applications and services in a Linux system.
tl;dr PAM handles authentication for multiple services on Linux OS.
This utility requires mailgun's API to allow scripting in use of their SMTP. Therefore, when attempting to connect your server via SSH, it will process /etc/pam.d/sshd
in regards to the shell script's location pam_alert.sh
.
Be aware! The following steps were tested with Ubuntu 18.04
- You will be required to sign up to mailgun's website to acquire the API.
- Install
pam.alert
git clone https://github.com/JustRLC/pam.alert
- Move directory to
/etc/pam.alert
sudo mv pam.alert /etc/pam.alert; sudo chmod 0755 /etc/pam.alert; cd /etc/pam.alert
- For security purposes, allow only the root user to have full privileges over the file.
sudo chmod 0700 pam_alert.sh
sudo chown root:root pam_alert.sh
- Edit
pam_alert.sh
using a tool you desire (via nano or Vim) and add your Mailgun'sAPI
andDOMAIN
, andTO
(your email) e.g. gmail account. Then, save the file.
API='' #Your Mailgun API
DOMAIN='' #Domain provided by Mailgun
TO='' #The email you want to send the alerts
- Locate to
/etc/pam.d/
and editsshd
within the directory. Add the following line and save it:
# SSH Alert script
session optional pam_exec.so /etc/pam.alert/pam_alert.sh
- Ta-dah! Now, you can exit the server and login again.
For testing purposes, the module is included as optional
, so that you can still log in if the execution fails. After you made sure that it works, you can change optional
to required
. Then login won't be possible unless the execution of your hook script is successful (Not essential, but I would recommend doing so.).