Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/keli/furion
Socks5 + SSL Proxy
https://github.com/keli/furion
proxy python socks5 ssl
Last synced: 26 days ago
JSON representation
Socks5 + SSL Proxy
- Host: GitHub
- URL: https://github.com/keli/furion
- Owner: keli
- License: bsd-2-clause
- Created: 2013-05-19T10:02:57.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2022-10-16T15:40:34.000Z (about 2 years ago)
- Last Synced: 2024-04-24T12:18:05.126Z (8 months ago)
- Topics: proxy, python, socks5, ssl
- Language: Python
- Size: 172 KB
- Stars: 45
- Watchers: 8
- Forks: 13
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: HISTORY.rst
- License: LICENSE
Awesome Lists containing this project
- awesome-network-stuff - **39**星
README
Furion Socks5 SSL Proxy
=======================Furion is an encrypted proxy written in Python. In essence, it's just socks5 server with ssl support. It's often used with upstream Furion servers to avoid censorship.
Features
--------- Automatic upstream fail over (when multiple upstream servers are available).
- Built-in latency check for choosing the fastest upstream.
- Periodical upstream updates from a designated central registry.
- Builtin DNS server/proxy to avoid poisoning.
- Limit what ports that clients are allowed to connect to.
- Easy account management on the server side.Dependencies
------------Furion has no external dependencies other than a standard Python 3.x (>=3.8) installation. There is optional support for gevent, which would be used if an existing gevent installation was discovered.
Installation
------------Furion can be installed via pip:
pip install furion
or pipx
pipx install furion
To start using Furion, you need at least a furion.cfg file.
By default, Furion will look for furion.cfg and upstream.json in `/etc/furion` or the current working directory. You can specify path to the configuration file after a `-c` switch.
For client, an upstream.json file is also needed for upstream checking to work in the same directory your furion.cfg resides in.
Alternatively, you can put the upstream.json file somewhere accessible via http(s), so that you can share that address with your friends. Then configure the `upstream` section of your `furion.cfg` file like below, to use that upstream file.
[upstream]
central_url = https://your.upstream.json
autoupdate_upstream_list = on
update_frequency = start
upstream_list_path = upstream.json
Read configuration files in [examples](https://github.com/keli/furion/blob/master/examples) directory for more information.
### Building Standalone Windows Clients
* Install miniconda3
```
winget install miniconda3
```* Create a new conda environment
```
conda create -n furion
```* Activate the environment
```
conda activate furion
```* Install pyinstaller
```
conda install -c conda-forge pyinstaller
```* Install wxPython (optional if you only want to build the cli version)
```
conda install -c conda-forge wxpython
```* Install furion itself
```
cd furion
pip install -e .
```* Build the standalone client
```
cd scripts/pyinstaller
pyinstaller.bat
```* The standalone clients will be in `dist/furion.exe` and `dist/furion-cli.exe`
* Furion.exe is only a tray icon currently.Note: You need to put a config file `furion.cfg` in the same directory of the exe for it to work.