Add ansible playbook for obfs4-openvpn server
This commit is contained in:
commit
4762f3d96e
6 changed files with 236 additions and 0 deletions
164
.gitignore
vendored
Normal file
164
.gitignore
vendored
Normal file
|
@ -0,0 +1,164 @@
|
||||||
|
|
||||||
|
# Created by https://www.gitignore.io/api/macos,python,ansible
|
||||||
|
# Edit at https://www.gitignore.io/?templates=macos,python,ansible
|
||||||
|
|
||||||
|
### Ansible ###
|
||||||
|
*.retry
|
||||||
|
|
||||||
|
### macOS ###
|
||||||
|
# General
|
||||||
|
.DS_Store
|
||||||
|
.AppleDouble
|
||||||
|
.LSOverride
|
||||||
|
|
||||||
|
# Icon must end with two \r
|
||||||
|
Icon
|
||||||
|
|
||||||
|
# Thumbnails
|
||||||
|
._*
|
||||||
|
|
||||||
|
# Files that might appear in the root of a volume
|
||||||
|
.DocumentRevisions-V100
|
||||||
|
.fseventsd
|
||||||
|
.Spotlight-V100
|
||||||
|
.TemporaryItems
|
||||||
|
.Trashes
|
||||||
|
.VolumeIcon.icns
|
||||||
|
.com.apple.timemachine.donotpresent
|
||||||
|
|
||||||
|
# Directories potentially created on remote AFP share
|
||||||
|
.AppleDB
|
||||||
|
.AppleDesktop
|
||||||
|
Network Trash Folder
|
||||||
|
Temporary Items
|
||||||
|
.apdisk
|
||||||
|
|
||||||
|
### Python ###
|
||||||
|
# Byte-compiled / optimized / DLL files
|
||||||
|
__pycache__/
|
||||||
|
*.py[cod]
|
||||||
|
*$py.class
|
||||||
|
|
||||||
|
# C extensions
|
||||||
|
*.so
|
||||||
|
|
||||||
|
# Distribution / packaging
|
||||||
|
.Python
|
||||||
|
build/
|
||||||
|
develop-eggs/
|
||||||
|
dist/
|
||||||
|
downloads/
|
||||||
|
eggs/
|
||||||
|
.eggs/
|
||||||
|
lib/
|
||||||
|
lib64/
|
||||||
|
parts/
|
||||||
|
sdist/
|
||||||
|
var/
|
||||||
|
wheels/
|
||||||
|
pip-wheel-metadata/
|
||||||
|
share/python-wheels/
|
||||||
|
*.egg-info/
|
||||||
|
.installed.cfg
|
||||||
|
*.egg
|
||||||
|
MANIFEST
|
||||||
|
|
||||||
|
# PyInstaller
|
||||||
|
# Usually these files are written by a python script from a template
|
||||||
|
# before PyInstaller builds the exe, so as to inject date/other infos into it.
|
||||||
|
*.manifest
|
||||||
|
*.spec
|
||||||
|
|
||||||
|
# Installer logs
|
||||||
|
pip-log.txt
|
||||||
|
pip-delete-this-directory.txt
|
||||||
|
|
||||||
|
# Unit test / coverage reports
|
||||||
|
htmlcov/
|
||||||
|
.tox/
|
||||||
|
.nox/
|
||||||
|
.coverage
|
||||||
|
.coverage.*
|
||||||
|
.cache
|
||||||
|
nosetests.xml
|
||||||
|
coverage.xml
|
||||||
|
*.cover
|
||||||
|
.hypothesis/
|
||||||
|
.pytest_cache/
|
||||||
|
|
||||||
|
# Translations
|
||||||
|
*.mo
|
||||||
|
*.pot
|
||||||
|
|
||||||
|
# Django stuff:
|
||||||
|
*.log
|
||||||
|
local_settings.py
|
||||||
|
db.sqlite3
|
||||||
|
|
||||||
|
# Flask stuff:
|
||||||
|
instance/
|
||||||
|
.webassets-cache
|
||||||
|
|
||||||
|
# Scrapy stuff:
|
||||||
|
.scrapy
|
||||||
|
|
||||||
|
# Sphinx documentation
|
||||||
|
docs/_build/
|
||||||
|
|
||||||
|
# PyBuilder
|
||||||
|
target/
|
||||||
|
|
||||||
|
# Jupyter Notebook
|
||||||
|
.ipynb_checkpoints
|
||||||
|
|
||||||
|
# IPython
|
||||||
|
profile_default/
|
||||||
|
ipython_config.py
|
||||||
|
|
||||||
|
# pyenv
|
||||||
|
.python-version
|
||||||
|
|
||||||
|
# pipenv
|
||||||
|
# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control.
|
||||||
|
# However, in case of collaboration, if having platform-specific dependencies or dependencies
|
||||||
|
# having no cross-platform support, pipenv may install dependencies that don’t work, or not
|
||||||
|
# install all needed dependencies.
|
||||||
|
#Pipfile.lock
|
||||||
|
|
||||||
|
# celery beat schedule file
|
||||||
|
celerybeat-schedule
|
||||||
|
|
||||||
|
# SageMath parsed files
|
||||||
|
*.sage.py
|
||||||
|
|
||||||
|
# Environments
|
||||||
|
.env
|
||||||
|
.venv
|
||||||
|
env/
|
||||||
|
venv/
|
||||||
|
ENV/
|
||||||
|
env.bak/
|
||||||
|
venv.bak/
|
||||||
|
|
||||||
|
# Spyder project settings
|
||||||
|
.spyderproject
|
||||||
|
.spyproject
|
||||||
|
|
||||||
|
# Rope project settings
|
||||||
|
.ropeproject
|
||||||
|
|
||||||
|
# mkdocs documentation
|
||||||
|
/site
|
||||||
|
|
||||||
|
# mypy
|
||||||
|
.mypy_cache/
|
||||||
|
.dmypy.json
|
||||||
|
dmypy.json
|
||||||
|
|
||||||
|
# Pyre type checker
|
||||||
|
.pyre/
|
||||||
|
|
||||||
|
# Downloaded files
|
||||||
|
root@*
|
||||||
|
|
||||||
|
# End of https://www.gitignore.io/api/macos,python,ansible
|
2
obfs4-openvpn-server/ansible.cfg
Normal file
2
obfs4-openvpn-server/ansible.cfg
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
[defaults]
|
||||||
|
hostfile = hosts
|
2
obfs4-openvpn-server/hosts
Normal file
2
obfs4-openvpn-server/hosts
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
[vpnservers]
|
||||||
|
#user@ip
|
5
obfs4-openvpn-server/obfs4.config
Normal file
5
obfs4-openvpn-server/obfs4.config
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
TOR_PT_MANAGED_TRANSPORT_VER=1
|
||||||
|
TOR_PT_STATE_LOCATION=/var/lib/tor/pt_state/obfs4
|
||||||
|
TOR_PT_SERVER_TRANSPORTS=obfs4
|
||||||
|
TOR_PT_SERVER_BINDADDR=obfs4-0.0.0.0:443
|
||||||
|
TOR_PT_ORPORT=127.0.0.1:1194
|
9
obfs4-openvpn-server/obfs4proxy.service
Normal file
9
obfs4-openvpn-server/obfs4proxy.service
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
[Unit]
|
||||||
|
Description=Obfsproxy Server
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
EnvironmentFile=/var/lib/tor/pt_state/obfs4/obfs4.config
|
||||||
|
ExecStart=/usr/bin/obfs4proxy -enableLogging true -logLevelStr INFO
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
54
obfs4-openvpn-server/playbook.yml
Executable file
54
obfs4-openvpn-server/playbook.yml
Executable file
|
@ -0,0 +1,54 @@
|
||||||
|
- hosts: vpnservers
|
||||||
|
gather_facts: yes
|
||||||
|
become_user: root
|
||||||
|
tasks:
|
||||||
|
tasks:
|
||||||
|
- name: Install python 2
|
||||||
|
raw: test -e /usr/bin/python || (apt -y update && apt install -y python-minimal)
|
||||||
|
- name: Download OpenVPN install script.
|
||||||
|
get_url:
|
||||||
|
url: https://raw.githubusercontent.com/angristan/openvpn-install/master/openvpn-install.sh
|
||||||
|
dest: /etc/openvpn-install.sh
|
||||||
|
- name: Install OpenVPN
|
||||||
|
command: bash /etc/openvpn-install.sh
|
||||||
|
environment:
|
||||||
|
APPROVE_INSTALL: y
|
||||||
|
APPROVE_IP: y
|
||||||
|
IPV6_SUPPORT: n
|
||||||
|
PORT_CHOICE: 1
|
||||||
|
PROTOCOL_CHOICE: 2
|
||||||
|
DNS: 7
|
||||||
|
COMPRESSION_ENABLED: n
|
||||||
|
CUSTOMIZE_ENC: n
|
||||||
|
CLIENT: client
|
||||||
|
PASS: 1
|
||||||
|
- name: Retrieve the OpenVPN client file.
|
||||||
|
fetch:
|
||||||
|
src: /root/client.ovpn
|
||||||
|
dest: .
|
||||||
|
mode: 0774
|
||||||
|
- name: Install obfsproxy
|
||||||
|
apt: pkg=obfs4proxy state=present
|
||||||
|
- name: Creates obfs4 directories
|
||||||
|
file:
|
||||||
|
path: /var/lib/tor/pt_state/obfs4
|
||||||
|
state: directory
|
||||||
|
- name: Copy obfs4 config from host to remote
|
||||||
|
copy:
|
||||||
|
src: obfs4.config
|
||||||
|
dest: /var/lib/tor/pt_state/obfs4/obfs4.config
|
||||||
|
- name: Create systemd service for obfs4
|
||||||
|
copy:
|
||||||
|
src: obfs4proxy.service
|
||||||
|
dest: /etc/systemd/system/obfs4proxy.service
|
||||||
|
- name: Enable the obfs4proxy systemd service
|
||||||
|
systemd:
|
||||||
|
name: obfs4proxy
|
||||||
|
state: started
|
||||||
|
enabled: yes
|
||||||
|
- name: Retrieve the obs4 cert key file.
|
||||||
|
fetch:
|
||||||
|
src: /var/lib/tor/pt_state/obfs4/obfs4_bridgeline.txt
|
||||||
|
dest: .
|
||||||
|
mode: 0774
|
||||||
|
|
Loading…
Add table
Reference in a new issue