A Python library for fetching real IP and Port using STUN servers and easily integratable with Python backend frameworks.
Project description
📜 conexia
A Python library for fetching and caching a device's real public IP address using STUN (Session Traversal Utilities for NAT) servers. Supports Redis, SQLite, File-based, and In-Memory caching for fast lookups.
📌 Why Use This?
- Identifies real public IP address even behind NAT.
- Optional caching feature
- Provides multiple cache backends (Redis, SQLite, File, Memory).
- Provide middleware support for Django and Flask
- Implement caching mechanisms for performance optimization
- Additional network parameters in fetched stun info - region, country, cordinates, timezone, ISP info etc
📦 Installation
pip install conexia
or install from source:
git clone https://github.com/paulsonlegacy/conexia.git
cd conexia
pip install .
⚡ Usage
Basic Example
from conexia.core import STUNClient
# Initialize engine
client = STUNClient()
# Fetch full network info
network_info = client.get_network_info()
# Fetch IP
ip = client.get_public_ip()
# Fetch port
port = client.get_public_port()
# Fetch NAT type
nat_type = client.get_nat_type()
# Fetch city
city = client.get_city()
# Fetch region
region = client.get_region()
# Fetch country
country = client.get_country()
# Fetch continent
continent = client.get_continent()
# Fetch cordinate
cordinate = client.get_cordinate()
# Fetch ISP info
isp_info = client.get_isp_info()
# Fetch timezone
timezone = client.get_timezone()
# Print full data
print(network_info)
Or run via command line after installation
conexia
📌 Output (Example)
{
'user_id': '667bd38c-e702-4295-9650-3afe5bacc361',
'data': {
'ip': '102.90.100.117',
'port': 10134,
'nat_type': 'Full Cone',
'city': 'Port Harcourt',
'region': 'Rivers State',
'country': 'NG',
'continent': 'Africa',
'cord': '4.7774,7.0134',
'isp_info': 'MTN NIGERIA Communication limited',
'timezone': 'Africa/Lagos'
},
'timestamp': 1739771764.9438107
}
NB - User ID is optional as it is automatically generated if not provided
🔌 Integrating with Django
1️⃣ Install the package
pip install conexia
2️⃣ Enable the STUN Middleware in settings.py Modify settings.py to activate the middleware and configure caching options:
# settings.py
MIDDLEWARE = [
"django.middleware.security.SecurityMiddleware",
"django.contrib.sessions.middleware.SessionMiddleware",
"django.middleware.common.CommonMiddleware",
"django.middleware.csrf.CsrfViewMiddleware",
"django.contrib.auth.middleware.AuthenticationMiddleware",
"django.contrib.messages.middleware.MessageMiddleware",
"django.middleware.clickjacking.XFrameOptionsMiddleware",
# ✅ Add Conexia Middleware
"conexia.middleware.django.STUNMiddleware",
]
# STUN Configuration
STUN_CACHE_BACKEND = "sqlite" # Options: "memory", "file", "sqlite", "redis"
STUN_CACHE_TTL = 300 # Cache expiry in seconds
3️⃣ Access STUN data inside Django Views Once the middleware is enabled, every request object will have the following attributes:
from django.http import JsonResponse
def sample_view(request):
return JsonResponse({
"ip": request.ip,
"port": request.port,
"nat_type": request.nat_type,
"city": request.city,
"region": request.region,
"country": request.country,
"continent": request.continent,
"timezone": request.timezone
})
🌐 Integrating with Flask
📌 Flask Integration Via Middleware
1️⃣ Install Flask and Conexia if you haven’t already
pip install flask conexia
2️⃣ Create app.py with the STUN middleware
from flask import Flask, jsonify, g
from conexia.core import STUNClient
from stun_middleware import STUNMiddleware # Import the middleware
app = Flask(__name__)
# Attach STUN Middleware with configurable options
STUNMiddleware(
app,
cache_backend="redis", # Change cache backend if needed (file, memory, etc.)
ttl=300 # Set TTL for STUN data caching
)
@app.route("/get_ip")
def get_ip():
return jsonify({
"user_id": g.get("user_id"),
"ip": g.get("ip"),
"port": g.get("port"),
"nat_type": g.get("nat_type"),
"city": g.get("city"),
"region": g.get("region"),
"country": g.get("country"),
"continent": g.get("continent"),
"timezone": g.get("timezone")
})
if __name__ == "__main__":
app.run(debug=True) # Runs synchronously with Flask's built-in server
3️⃣ Run the Server Run the application using Flask's built-in WSGI server:
python app.py
Flask will start at:
http://127.0.0.1:5000
4️⃣ Test API in Browser or Postman You can test the STUN attributes by making a request:
http://127.0.0.1:5000/get_ip
Example response:
{
'ip': '102.90.100.117',
'port': 10134,
'nat_type': 'Full Cone',
'city': 'Port Harcourt',
'region': 'Rivers State',
'country': 'NG',
'continent': 'Africa',
'timezone': 'Africa/Lagos'
}
✅ Alternative: Using Flask Hooks for STUN Info
If you prefer adding STUN information manually before each request, you can do:
from flask import Flask, g, request
from conexia.core import STUNClient
app = Flask(__name__)
stun_client = STUNClient(backend="redis", ttl=300)
@app.before_request
def attach_stun_data():
user_id = request.args.get("user_id", "default_id")
stun_info = stun_client.get_network_info(user_id)
g.ip = stun_info['data']['ip']
g.port = stun_info['data']['port']
g.nat_type = stun_info['data']['nat_type']
g.user_id = user_id # Store user ID in Flask's request context
@app.route("/get_ip")
def get_ip():
return jsonify({
"ip": g.get("ip"),
"port": g.get("port"),
"nat_type": g.get("nat_type"),
"user_id": g.get("user_id")
})
if __name__ == "__main__":
app.run(debug=True)
This approach attaches STUN data before every request without requiring custom middleware.
Conclusion:
✅ Middleware automatically attaches STUN data
✅ Flask hooks can be used as an alternative
✅ Works natively with Flask (no async needed)
💾 Available Cache Backends
| Cache Backend | Description |
|---|---|
memory |
Uses in-memory cache (Fast but not persistent). |
file |
Saves cached data in cache.json (Persistent across restarts). |
sqlite |
Uses an SQLite database for efficient storage. |
redis |
Uses Redis for distributed caching. |
NB - Default is file
🔧 Clearing Cache
Clear cache for a specific user ID:
stun_client.clear_cache(user_id="device123")
Clear all cached data:
stun_client.clear_cache()
📜 License
This project is licensed under the MIT License.
👨💻 Contributing
1️⃣ Fork the repository
2️⃣ Clone your fork
git clone https://github.com/paulsonlegacy/conexia.git
cd conexia
3️⃣ Create a feature branch
git checkout -b feature-name
4️⃣ Submit a pull request! 🚀
🙌 Acknowledgments
🎉 This library is specially dedicated to my mom - Monica A. Bosah, whose support made this possible; and to Engr. Hussein Nasser who not only sparked the idea that birthed this library through his backend engineering course on Udemy, but impacted in me alot through his wealth of knowledge, thinking and approach to solving problems ❤️
🚀 Next Steps
- Implement a simple WebSocket signaling server.
- Extend conexia to generate ICE candidates & SDP.
- Test peer-to-peer chat by exchanging SDP via WebSocket.
- Package a CLI tool to allow remote users to connect and chat.
- Remote file sharing.
💡 Want More Features?
If you have feature suggestions or bugs, open an issue on GitHub! 🚀
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file conexia-0.2.0.tar.gz.
File metadata
- Download URL: conexia-0.2.0.tar.gz
- Upload date:
- Size: 15.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ad97adb7517ab311422673f9174c452972ee8a3f6dc50e0e4890f5dc5b5618f6
|
|
| MD5 |
4dbb6257e88c4c2ddebf4ffe56ece722
|
|
| BLAKE2b-256 |
667b6497e342295665d31a5eb0e90dc440318e738b70625e46e82359ad1c8297
|
File details
Details for the file conexia-0.2.0-py3-none-any.whl.
File metadata
- Download URL: conexia-0.2.0-py3-none-any.whl
- Upload date:
- Size: 14.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.10.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ccb1c5b7597c9545b2d36031992dfc4532c7147a33a7917c1766dbd85baa8f9b
|
|
| MD5 |
fdd820bc3e640372ef43d253f67df289
|
|
| BLAKE2b-256 |
efdc3228a6532a0332c9121d9ab7fba9bd3b85360d34b7de8d7007a00c6678fe
|