Gathering detailed insights and metrics for krowdy-geoip
Gathering detailed insights and metrics for krowdy-geoip
Gathering detailed insights and metrics for krowdy-geoip
Gathering detailed insights and metrics for krowdy-geoip
Less memory usage version of geoip-lite, by supporting only country lookup.
npm install krowdy-geoip
Typescript
Module System
Min. Node Version
Node Version
NPM Version
JavaScript (99.25%)
Shell (0.75%)
Total Downloads
0
Last Day
0
Last Week
0
Last Month
0
Last Year
0
NOASSERTION License
3 Commits
1 Watchers
1 Branches
1 Contributors
Updated on Jul 07, 2021
Latest Version
1.0.2
Package Id
krowdy-geoip@1.0.2
Unpacked Size
5.54 MB
Size
1.82 MB
File Count
14
NPM Version
6.13.4
Node Version
12.16.0
Cumulative downloads
Total Downloads
Last Day
0%
NaN
Compared to previous day
Last Week
0%
NaN
Compared to previous week
Last Month
0%
NaN
Compared to previous month
Last Year
0%
NaN
Compared to previous year
8
1
Less memory usage version of geoip-lite by limiting to country information. This product includes GeoLite2 ipv4 and ipv6 country data which created by MaxMind, available from https://www.maxmind.com. The database of this product updates weekly.
You should read this README and the LICENSE and EULA files carefully before deciding to use this product.
After v4, LICENSE for the database was changed. If you need to use this product with previous LICENSE, please use v3.
1var geoip = require('krowdy-geoip'); 2 3var ip = "207.97.227.239"; 4var geo = geoip.lookup(ip); 5 6console.log(geo); 7{ range: [ 3479299040, 3479299071 ], 8 country: 'US'}
$ npm install krowdy-geoip
$ npm run-script updatedb --license_key=YOUR_GEOLITE2_LICENSE_KEY
or
$ GEOLITE2_LICENSE_KEY=YOUR_GEOLITE2_LICENSE_KEY node scripts/updatedb.js
YOUR_GEOLITE2_LICENSE_KEY should be replaced by a valid GeoLite2 license key. Please follow instructions provided by MaxMind to obtain a license key.
krowdy-geoip is completely synchronous. There are no callbacks involved. All blocking file IO is done at startup time, so all runtime calls are executed in-memory and are fast. Startup may take up to 20ms while it reads into memory and indexes data files.
If you have an IP address in dotted quad notation, IPv6 colon notation, or a 32 bit unsigned integer (treated
as an IPv4 address), pass it to the lookup
method. Note that you should remove any [
and ]
around an
IPv6 address before passing it to this method.
1var geo = geoip.lookup(ip);
If the IP address was found, the lookup
method returns an object with the following structure:
1{ 2 range: [ <low bound of IP block>, <high bound of IP block> ], 3 country: 'XX' // 2 letter ISO-3166-1 country code 4}
The actual values for the range
array depend on whether the IP is IPv4 or IPv6 and should be
considered internal to krowdy-geoip
. To get a human readable format, pass them to geoip.pretty()
If the IP address was not found, the lookup
returns null
If you have a 32 bit unsigned integer, or a number returned as part of the range
array from the lookup
method,
the pretty
method can be used to turn it into a human readable string.
1 console.log("The IP is %s", geoip.pretty(ip));
This method returns a string if the input was in a format that krowdy-geoip
can recognize, else it returns the
input itself.
This package contains an update script that can pull the files from MaxMind and handle the conversion from CSV. A npm script alias has been setup to make this process easy. Please keep in mind this requires internet and MaxMind rate limits that amount of downloads on their servers.
1npm run-script updatedb --license_key=YOUR_GEOLITE2_LICENSE_KEY 2 or 3GEOLITE2_LICENSE_KEY=YOUR_GEOLITE2_LICENSE_KEY node scripts/updatedb.js
YOUR_GEOLITE2_LICENSE_KEY should be replaced by a valid GeoLite2 license key. Please follow instructions provided by MaxMind to obtain a license key.
Please carefully read the LICENSE and EULA files. This package comes with certain restrictions and obligations, most notably:
You can read the latest version of GeoLite2 EULA.
No vulnerabilities found.
Reason
no dangerous workflow patterns detected
Reason
no binaries found in the repo
Reason
0 existing vulnerabilities detected
Reason
license file detected
Details
Reason
Found 0/3 approved changesets -- score normalized to 0
Reason
detected GitHub workflow tokens with excessive permissions
Details
Reason
0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0
Reason
no SAST tool detected
Details
Reason
no effort to earn an OpenSSF best practices badge detected
Reason
security policy file not detected
Details
Reason
project is not fuzzed
Details
Reason
branch protection not enabled on development/release branches
Details
Reason
dependency not pinned by hash detected -- score normalized to 0
Details
Score
Last Scanned on 2025-07-07
The Open Source Security Foundation is a cross-industry collaboration to improve the security of open source software (OSS). The Scorecard provides security health metrics for open source projects.
Learn More