Skip to main content

A tool for exploring the Tor network

Project description

Note: This project was written by Claude, an AI assistant by Anthropic, under human guidance using Claude Code.

Overview

torscope is a tool for exploring the Tor network.

It implements the Tor directory protocol and OR (Onion Router) protocol, allowing you to explore relay information, create circuits, and study the Tor specification in practice.

Features

  • Explore Tor directory (authorities, relays, consensus)
  • Build circuits through the network (1-3 hops)
  • Connect to clearnet and .onion sites
  • Bridge support (direct, WebTunnel, obfs4)
  • Hidden service access with client authorization
  • DNS resolution through Tor
  • Web interface with real-time circuit visualization on a world map
  • REST API for programmatic access

See FEATURES.md for detailed protocol support.

Installation

pip install torscope

Usage

# List directory authorities
torscope authorities

# List routers with specific flags
torscope routers --flags Guard,Exit

# Show router details
torscope router moria1

# Build a 3-hop circuit
torscope circuit

# Resolve hostname through Tor
torscope resolve example.com

# Connect to a website through Tor
torscope open-stream example.com:80 --http-get

# Connect with IPv6 preferences
torscope open-stream example.com:80 --http-get --ipv6-ok --ipv6-preferred

# Access a hidden service
torscope hidden-service duckduckgogg42xjoc72x3sjasowoarfbgcmvfimaftt6twagswzczad.onion

# Connect to a hidden service
torscope open-stream duckduckgogg42xjoc72x3sjasowoarfbgcmvfimaftt6twagswzczad.onion:80 --http-get

# Access a private hidden service with client authorization
torscope hidden-service private.onion --auth-key-file ~/.tor/onion_auth/private.auth_private
torscope open-stream private.onion:80 --auth-key-file ~/.tor/onion_auth/private.auth_private

# Build circuit through a direct bridge (no transport)
torscope circuit --bridge "192.0.2.1:443 4352E58420E68F5E40BF7C74FADDCCD9D1349413"

# Build circuit through a WebTunnel bridge
torscope circuit --bridge "webtunnel 192.0.2.1:443 FINGERPRINT url=https://example.com/secret-path"

# Build circuit through an obfs4 bridge
torscope circuit --bridge "obfs4 192.0.2.1:443 FINGERPRINT cert=ABC...xyz iat-mode=0"

# Open stream through a bridge
torscope open-stream example.com:80 --bridge "192.0.2.1:443 FINGERPRINT" --http-get

# Open stream through an obfs4 bridge
torscope open-stream example.com:80 --bridge "obfs4 192.0.2.1:443 FINGERPRINT cert=... iat-mode=0" --http-get

Web Interface

Start the web server to visualize circuits on a map:

# Start the API server
torscope serve

# Start on a specific port
torscope serve --port 3000

# Bind to localhost only
torscope serve --host 127.0.0.1

# With GeoIP database for router locations
torscope serve --geoip-db /path/to/GeoLite2-City.mmdb

Then open http://localhost:8000 in your browser. The web interface allows you to:

  • Build circuits and visualize the path on a world map
  • View all Tor routers with color-coded markers (Guard, Exit, Middle)
  • View directory servers (Authorities, Fallbacks, Caches)
  • See responsible HSDirs when connecting to .onion addresses

Verbosity Flags

-e, --explain   # Brief explanations of what's happening
-v              # Protocol-level information
-vv             # Raw debug information (implies -v)

Example Onion Addresses

  • duckduckgogg42xjoc72x3sjasowoarfbgcmvfimaftt6twagswzczad.onion
  • 2gzyxa5ihm7nsggfxnu52rck2vv4rvmdlkiu3zzui5du4xyclen53wid.onion
  • torscope75efu4gls3m24xezterv7nhj36ibnjlrocqeslclwbxgs7yd.onion

License

torscope Tor Network Exploration Tool

Copyright (C) 2025-2026 Mete Balci

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see https://www.gnu.org/licenses/.

References

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

torscope-0.8.0.tar.gz (234.8 kB view details)

Uploaded Source

Built Distribution

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

torscope-0.8.0-py3-none-any.whl (190.7 kB view details)

Uploaded Python 3

File details

Details for the file torscope-0.8.0.tar.gz.

File metadata

  • Download URL: torscope-0.8.0.tar.gz
  • Upload date:
  • Size: 234.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for torscope-0.8.0.tar.gz
Algorithm Hash digest
SHA256 51f7d5e303b18bd79a0979e9056eae3347b0ae6ee038537e8ba83417d74616df
MD5 982ddc449f718044ac1b22a1c1977501
BLAKE2b-256 8c2accb113c012e5f4083e7ec7b7bf156b8fb6404eeb24c443675193183b9176

See more details on using hashes here.

File details

Details for the file torscope-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: torscope-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 190.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for torscope-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 26473300a8e1f7f4126328a1312700a8784f9da7775820d580d7266b9635f096
MD5 d68b7726dd804431e77e0277c668c681
BLAKE2b-256 ecd903672d61bf579979b84c1a6c9e915bb345a1744ce64b50c580ce1710be60

See more details on using hashes here.

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