Skip to content

IP2Proxy Lua package allows users to query an IP address to determine if it was being used as open proxy, web proxy, VPN anonymizer and TOR exits.

License

Notifications You must be signed in to change notification settings

ip2location/ip2proxy-lua

Repository files navigation

IP2Proxy Lua Package

This package allows user to query an IP address if it was being used as VPN anonymizer, open proxies, web proxies, Tor exits, data center, web hosting (DCH) range, search engine robots (SES) and residential (RES). It lookup the proxy IP address from IP2Proxy BIN Data file. This data file can be downloaded at

As an alternative, this package can also call the IP2Proxy Web Service. This requires an API key. If you don't have an existing API key, you can subscribe for one at the below:

https://www.ip2location.com/web-service/ip2proxy

Installation

luarocks install ip2proxy

QUERY USING THE BIN FILE

Functions

Below are the functions supported in this package.

Function Name Description
open Open the IP2Proxy BIN data for lookup.
close Close and clean up the file pointer.
get_package_version Get the package version (1 to 11 for PX1 to PX11 respectively).
get_module_version Get the module version.
get_database_version Get the database version.
isproxy Check whether if an IP address was a proxy. Returned value:
  • -1 : errors
  • 0 : not a proxy
  • 1 : a proxy
  • 2 : a data center IP address or search engine robot
get_all Return the proxy information in an object.
get_proxytype Return the proxy type. Please visit IP2Location for the list of proxy types supported
get_country_short Return the ISO3166-1 country code (2-digits) of the proxy.
get_country_long Return the ISO3166-1 country name of the proxy.
get_region Return the ISO3166-2 region name of the proxy. Please visit ISO3166-2 Subdivision Code for the information of ISO3166-2 supported
get_city Return the city name of the proxy.
get_isp Return the ISP name of the proxy.
get_domain Return the domain name of the proxy.
get_usagetype Return the usage type classification of the proxy. Please visit IP2Location for the list of usage types supported.
get_asn Return the autonomous system number of the proxy.
get_as Return the autonomous system name of the proxy.
get_lastseen Return the number of days that the proxy was last seen.
get_threat Return the threat type of the proxy.
get_provider Return the provider of the proxy.

Usage

ip2proxy = require('ip2proxy')

local ip2prox = ip2proxy:open('/usr/data/IP2PROXY-IP-PROXYTYPE-COUNTRY-REGION-CITY-ISP-DOMAIN-USAGETYPE-ASN-LASTSEEN-THREAT-RESIDENTIAL-PROVIDER.BIN')

local result = ip2prox:get_all('8.8.8.8')

print("country_short: " .. result.country_short)
print("country_long: " .. result.country_long)
print("region: " .. result.region)
print("city: " .. result.city)
print("isp: " .. result.isp)
print("domain: " .. result.domain)
print("usagetype: " .. result.usagetype)
print("asn: " .. result.asn)
print("as: " .. result.as)
print("lastseen: " .. result.lastseen)
print("threat: " .. result.threat)
print("provider: " .. result.provider)
print("proxytype: " .. result.proxytype)
print("isproxy: " .. result.isproxy)

ip2prox:close()

QUERY USING THE IP2PROXY PROXY DETECTION WEB SERVICE

Functions

Below are the functions supported in this package.

Function Name Description
open Expects 3 input parameters:
  1. IP2Proxy API Key.
  2. Package (PX1 - PX11)
  3. Use HTTPS or HTTP
lookup Query IP address. This function returns a table containing the proxy info.
  • countryCode
  • countryName
  • regionName
  • cityName
  • isp
  • domain
  • usageType
  • asn
  • as
  • lastSeen
  • threat
  • proxyType
  • isProxy
  • provider
    get_credit This function returns the web service credit balance in a table.

    Usage

    ip2proxywebservice = require('ip2proxywebservice')
    
    local apikey = 'YOUR_API_KEY'
    local apipackage = 'PX11'
    local usessl = true
    local ip = '8.8.8.8'
    local ws = ip2proxywebservice:open(apikey, apipackage, usessl)
    
    local result = ws:lookup(ip)
    
    print("response: " .. result.response)
    print("countryCode: " .. result.countryCode)
    print("countryName: " .. result.countryName)
    print("regionName: " .. result.regionName)
    print("cityName: " .. result.cityName)
    print("isp: " .. result.isp)
    print("domain: " .. result.domain)
    print("usageType: " .. result.usageType)
    print("asn: " .. result.asn)
    print("as: " .. result.as)
    print("lastSeen: " .. result.lastSeen)
    print("threat: " .. result.threat)
    print("provider: " .. result.provider)
    print("proxyType: " .. result.proxyType)
    print("isProxy: " .. result.isProxy)
    
    local result2 = ws:get_credit()
    print("Credit Balance: " .. result2.response)
    

    About

    IP2Proxy Lua package allows users to query an IP address to determine if it was being used as open proxy, web proxy, VPN anonymizer and TOR exits.

    Resources

    License

    Stars

    Watchers

    Forks

    Packages

    No packages published

    Contributors 2

    •  
    •  

    Languages