Project

locality

0.0
No commit activity in last 3 years
No release in over 3 years
See https://github.com/bukowskis/locality
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

Runtime

 Project Readme

Locality

Postnummerservice

Installation

# Go and buy the rec2LK database from postnummerservice.se
# Put it in the ./db directory

Configuration

Locality.configure do |config|

  # By default, locality will look for the rec2LK database in
  # these locations: `Locality.config.postnummerfilen_paths`
  # You can add a custom location like so:
  config.postnummerfilen_path = '/some/custom/rec2LK.csv'

end

Usage

# A-Regions
# See https://sv.wikipedia.org/wiki/A-region
available_codes = Locality::Postnummerservice::Aregion.codes
lookup = Locality::Postnummerservice::Aregion.new 21  # Gotland

# States
# See https://sv.wikipedia.org/wiki/Sveriges_l%C3%A4n
available_codes = Locality::Postnummerservice::State.codes
lookup = Locality::Postnummerservice::State.new 7  # Kronoberg

# Provinces
# See https://sv.wikipedia.org/wiki/Sveriges_l%C3%A4n
available_codes = Locality::Postnummerservice::Province.codes
lookup = Locality::Postnummerservice::Province.new '0182'  # Nacka

# Zip Codes
# See https://sv.wikipedia.org/wiki/Postnummer_i_Sverige
lookup = Locality::Postnummerservice::ZipCode.new '11417'  # Stockholm

# On all of the above lookups you have the following attributes
lookup.code
lookup.name
lookup.zip_codes
lookup.city_names
lookup.state_codes
lookup.state_names
lookup.province_code
lookup.province_names
lookup.aregion_codes

# More to come...

IP Lookup

Installation

# Get the libmaxminddb, e.g. via homebrew on Mac OS
brew install libmaxminddb
# Download and extract the MaxMind GeoIp2 database
curl http://geolite.maxmind.com/download/geoip/database/GeoLite2-City.mmdb.gz -o ./db && gunzip ./db/GeoLite2-City.mmdb.gz

Configuration

Locality.configure do |config|

  # By default, locality will look for the maxmind database in
  # these locations: `Locality.config.maxmind_geoip2_paths`
  # You can add a custom location like so:
  config.maxmind_geoip2_path = '/some/custom/maxmind_geolite2.mmdb'

  # If you want, you can add custom lookups like so:
  config.add_custom_ip_location '198.51.100.99/24', city_name: 'Main Office', country_name: 'Australia'
end

Usage

# If you want to make sure on application
# bootup that everything works, call this method:
Locality::IP.check!

# Lookup an IP
lookup = Locality::IP.new '198.51.100.55'

# All these attributes return either a String or nil.
lookup.ip
lookup.city_name
lookup.province_name
lookup.state_name
lookup.country_name
lookup.human_readable_name

# Get them all combined in a Hash
lookup.to_hash