Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/meejah/txtorcon
Twisted-based asynchronous Tor control protocol implementation. Includes unit-tests, examples, state-tracking code and configuration abstraction.
https://github.com/meejah/txtorcon
async async-programming privacy python tor twisted
Last synced: 4 days ago
JSON representation
Twisted-based asynchronous Tor control protocol implementation. Includes unit-tests, examples, state-tracking code and configuration abstraction.
- Host: GitHub
- URL: https://github.com/meejah/txtorcon
- Owner: meejah
- License: mit
- Created: 2012-03-28T06:51:27.000Z (almost 13 years ago)
- Default Branch: main
- Last Pushed: 2024-03-13T22:37:50.000Z (10 months ago)
- Last Synced: 2024-04-16T03:51:31.472Z (9 months ago)
- Topics: async, async-programming, privacy, python, tor, twisted
- Language: Python
- Homepage: http://fjblvrw2jrxnhtg67qpbzi45r7ofojaoo3orzykesly2j3c2m3htapid.onion/
- Size: 3.87 MB
- Stars: 247
- Watchers: 27
- Forks: 71
- Open Issues: 46
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
- awesome-network-stuff - **197**星 - based asynchronous Tor control protocol implementation. Includes unit-tests, examples, state-tracking code and configuration abstraction. (<a id="6e80463404d46f0493cf6e84597e4b5c"></a>工具 / <a id="e99ba5f3de02f68412b13ca718a0afb6"></a>Tor&&&Onion&&洋葱)
README
.. _NOTE: see docs/index.rst for the starting-point
.. _ALSO: https://txtorcon.readthedocs.org for rendered docs.. image:: https://github.com/meejah/txtorcon/actions/workflows/python3.yaml/badge.svg
:target: https://github.com/meejah/txtorcon/actions
:alt: github-actions.. image:: https://coveralls.io/repos/meejah/txtorcon/badge.png?branch=main
:target: https://coveralls.io/github/meejah/txtorcon?branch=main
:alt: coveralls.. image:: https://codecov.io/github/meejah/txtorcon/coverage.svg?branch=main
:target: https://codecov.io/github/meejah/txtorcon?branch=main
:alt: codecov.. image:: https://readthedocs.org/projects/txtorcon/badge/?version=stable
:target: https://txtorcon.readthedocs.io/en/stable
:alt: ReadTheDocs.. image:: https://readthedocs.org/projects/txtorcon/badge/?version=latest
:target: https://txtorcon.readthedocs.io/en/latest
:alt: ReadTheDocstxtorcon
========- **docs**: https://txtorcon.readthedocs.org or http://fjblvrw2jrxnhtg67qpbzi45r7ofojaoo3orzykesly2j3c2m3htapid.onion/
- **code**: https://github.com/meejah/txtorcon
- ``torsocks git clone git://fjblvrw2jrxnhtg67qpbzi45r7ofojaoo3orzykesly2j3c2m3htapid.onion/txtorcon.git``
- MIT-licensed;
- Python 3.8+, PyPy 7.3.7+;
- depends on
`Twisted`_,
`Automat `_Ten Thousand Feet
-----------------txtorcon is an implementation of the `control-spec
`_
for `Tor `_ using the `Twisted`_
networking library for `Python `_.This is useful for writing utilities to control or make use of Tor in
event-based Python programs. If your Twisted program supports
endpoints (like ``twistd`` does) your server or client can make use of
Tor immediately, with no code changes. Start your own Tor or connect
to one and get live stream, circuit, relay updates; read and change
config; monitor events; build circuits; create onion services;
etcetera (`ReadTheDocs `_).Some Possibly Motivational Example Code
---------------------------------------`download `_
.. code:: python
from twisted.internet.task import react
from twisted.internet.defer import inlineCallbacks, ensureDeferred
from twisted.internet.endpoints import UNIXClientEndpointimport treq
import txtorconasync def main(reactor):
tor = await txtorcon.connect(
reactor,
UNIXClientEndpoint(reactor, "/var/run/tor/control")
)print("Connected to Tor version {}".format(tor.version))
url = u'https://www.torproject.org:443'
print(u"Downloading {}".format(repr(url)))
resp = await treq.get(url, agent=tor.web_agent())print(u" {} bytes".format(resp.length))
data = await resp.text()
print(u"Got {} bytes:\n{}\n[...]{}".format(
len(data),
data[:120],
data[-120:],
))print(u"Creating a circuit")
state = await tor.create_state()
circ = await state.build_circuit()
await circ.when_built()
print(u" path: {}".format(" -> ".join([r.ip for r in circ.path])))print(u"Downloading meejah's public key via above circuit...")
config = await tor.get_config()
resp = await treq.get(
u'https://meejah.ca/meejah.asc',
agent=circ.web_agent(reactor, config.socks_endpoint(reactor)),
)
data = await resp.text()
print(data)@react
def _main(reactor):
return ensureDeferred(main(reactor))Try It Now On Debian/Ubuntu
---------------------------For example, serve some files via an onion service (*aka* hidden
service):.. code-block:: shell-session
$ sudo apt-get install --install-suggests python3-txtorcon
$ twistd -n web --port "onion:80" --path ~/public_htmlRead More
---------All the documentation starts `in docs/index.rst
`_. Also hosted at `txtorcon.rtfd.org
`_.You'll want to start with `the introductions `_ (`hosted at RTD
`_)... _Twisted: https://twistedmatrix.com/trac