logfailmap
A module for extracting and locating IPs that failed to login to a Linux machine Note that logfailmap uses ipstack, which requires an API key. The free tier allows 10000 requests per month.
Features
- Retrieve IPs of machines that failed to connect to the machine from bad login logfile (btmp)
- Obtain geographical data about the IP addresses
Dependencies
- request - Simple HTTP request client
- stream-splitter - Library for splitting streams
- Standard Unix utilities (sh, last, awk)
Installation
npm install logfailmap
Example usage
var logfailmap = ;var apiKey = xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx; // IPStack API key ;
Attempts object
The attempts object contains one key/value pair for the date and time the information was retrieved. The rest of the keys are the IP addresses that failed to connect. The values are objects containing the geographical information for each IP, as well as the number of login attempts. Geographical information is obtained from ipstack and some IP addresses have less information available than others (e.g., no city). For example,
date: 'Sat Aug 08 2015 14:00:44 GMT-0400 (EDT)' connections: '8.8.8.8': longitude: -1220838 latitude: 37386 ip: '8.8.8.8' city: 'Mountain View' metro_code: 807 time_zone: 'America/Los_Angeles' region_name: 'California' country_code: 'US' country_name: 'United States' country_code: 'US' region_code: 'CA' zip_code: '94040' attempts: 5 '134.170.188.221': longitude: -97 latitude: 38 ip: '134.170.188.221' metro_code: 0 country_code: 'US' country_name: 'United States'