# Go and buy the rec2LK database from postnummerservice.se
# Put it in the ./db directory
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
# 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...
# 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
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
# 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