Skip to main content

Getting your public IP v4 and v6

Project description

Testing Build Publish

What is this?

License: MIT

Simple python module for getting your public IP V4 and V6 from several providers in random mode with also several protocols (DNS, HTTPS and STUN).

Supported providers

IP Checker HTTPS STUN DNS IPv4 IPv6 Use Policy
google ✔️ ✔️ ✔️ ✔️
cloudflare ✔️ ✔️ ✔️ ✔️
openDNS ✔️ ✔️ ✔️
akamai ✔️ ✔️ ✔️ ✔️
ipify ✔️ ✔️ ✔️
icanhazip ✔️ ✔️ ✔️
matrix ✔️ ✔️ ✔️
framasoft ✔️ ✔️ ✔️
ifconfig.me ✔️ ✔️ ✔️

Installation

python 3.13.x python 3.12.x python 3.11.x python 3.10.x

This module can be installed from pypi website

pip install publicaddr

Lookup for IPv4 and IPv6

Lookup for your public IPs from random providers with DNS or HTTP protocols with 3 retries if no ips are returned. This is the default behaviour of the lookup function.

import publicaddr

publicaddr.lookup()
{'ip4': 'x.x.x.x', 'ip6': 'x:x:x:x:x:x:x:x', 'provider': 'opendns',
'proto': 'dns', 'duration': '0.037'}

Configuration

This module can be configurated with environment variables

Variables Description
PUBLICADDR_DEBUG debug mode 1 or 0
PUBLICADDR_TIMEOUT timeout, default is 2s
PUBLICADDR_RETRIES retries, default is 3
PUBLICADDR_IPV6_ENABLED enable ipv6 with 1 or 0 to disable
PUBLICADDR_LOOKUP_HTTPS lookup with HTTPS protocol (1 or 0 to disable)
PUBLICADDR_LOOKUP_DNS lookup with DNS protocol (1 or 0 to disable)
PUBLICADDR_LOOKUP_STUN lookup with STUN protocol (1 or 0 to disable)

Specific lookups

Lookup for public IP with specific protocol

Lookup for your public IPs from random DNS providers with specific protocol.

import publicaddr

publicaddr.lookup(providers=publicaddr.DNS, retries=2)
{'ip4': 'x.x.x.x', 'ip6': 'x:x:x:x:x:x:x:x', 'provider': 'opendns',
'proto': 'dns', 'duration': '0.037'}

Default constants for transport protocol:

  • publicaddr.HTTPS
  • publicaddr.DNS
  • publicaddr.STUN

Get IPv4 or IPv6 only

Get your public IPv4 with default provider (Google with DNS protocol).

import publicaddr

publicaddr.get(ip=publicaddr.IPv4)
{'ip': 'x.x.x.x', 'duration': '0.025'}

Default constants for IP version:

  • publicaddr.IPv4
  • publicaddr.IPv6

Get IP with specific provider

Example to use the provider Cloudflare instead of the default one.

import publicaddr

myip = publicaddr.get(provider=publicaddr.CLOUDFLARE, proto=publicaddr.DNS)
{'ip': 'x:x:x:x:x:x:x:x', 'duration': '0.020'}

Default constants for providers:

  • publicaddr.CLOUDFLARE
  • publicaddr.GOOGLE
  • publicaddr.OPENDNS
  • publicaddr.AKAMAI
  • publicaddr.IPIFY
  • publicaddr.ICANHAZIP
  • publicaddr.MATRIX
  • publicaddr.FRAMASOFT
  • publicaddr.IFCONFIG_ME

For developpers

Run from source

sudo apt install python3-venv
python3 -m venv venv
source venv/bin/activate
python3 -m pip install -r requirements.txt
python3 example.py

Custom configuration

See the default configuration file

Run test units

python3 -m unittest discover tests/

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

publicaddr-0.18.0.tar.gz (10.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

publicaddr-0.18.0-py3-none-any.whl (16.6 kB view details)

Uploaded Python 3

File details

Details for the file publicaddr-0.18.0.tar.gz.

File metadata

  • Download URL: publicaddr-0.18.0.tar.gz
  • Upload date:
  • Size: 10.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for publicaddr-0.18.0.tar.gz
Algorithm Hash digest
SHA256 ca2bac70d4668ab1a2f0f78f741f8cfc38767e1a901bac91afaad42a9f41d0bb
MD5 df4c7ec82a66bb98b5d2514cbd635fcb
BLAKE2b-256 55be9af32ebfab42ab206fb472b5a89ed64e707fc808b0726d1f062721224c2f

See more details on using hashes here.

Provenance

The following attestation bundles were made for publicaddr-0.18.0.tar.gz:

Publisher: publish.yml on dmachard/python-publicaddr

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file publicaddr-0.18.0-py3-none-any.whl.

File metadata

  • Download URL: publicaddr-0.18.0-py3-none-any.whl
  • Upload date:
  • Size: 16.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for publicaddr-0.18.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e88721e5590f322d71235d3bd7e3ef561f05df1a1327c15f94bc63ed30c15be7
MD5 ed428d2e61531e8caacab49b5a56a8da
BLAKE2b-256 a99900d7eb77803ff54bc83473c8f1a3f112e35191e2e92125dbab59ff8d8aeb

See more details on using hashes here.

Provenance

The following attestation bundles were made for publicaddr-0.18.0-py3-none-any.whl:

Publisher: publish.yml on dmachard/python-publicaddr

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page