From 6e2c2eb10093938e02a0d44726f71f82c7ffc5b8 Mon Sep 17 00:00:00 2001 From: Aaron LI Date: Thu, 22 Feb 2018 00:21:22 +0800 Subject: Add role shadowsocks --- roles/shadowsocks/handlers/main.yml | 3 +++ roles/shadowsocks/tasks/main.yml | 32 ++++++++++++++++++++++++++++++ roles/shadowsocks/templates/config.json.j2 | 13 ++++++++++++ 3 files changed, 48 insertions(+) create mode 100644 roles/shadowsocks/handlers/main.yml create mode 100644 roles/shadowsocks/tasks/main.yml create mode 100644 roles/shadowsocks/templates/config.json.j2 (limited to 'roles') diff --git a/roles/shadowsocks/handlers/main.yml b/roles/shadowsocks/handlers/main.yml new file mode 100644 index 0000000..a4b1aec --- /dev/null +++ b/roles/shadowsocks/handlers/main.yml @@ -0,0 +1,3 @@ +--- +- name: restart-shadowsocks + command: rcrestart shadowsocks-libev diff --git a/roles/shadowsocks/tasks/main.yml b/roles/shadowsocks/tasks/main.yml new file mode 100644 index 0000000..5065085 --- /dev/null +++ b/roles/shadowsocks/tasks/main.yml @@ -0,0 +1,32 @@ +--- +- name: install shadowsocks-libev + pkgng: + name: shadowsocks-libev + state: present + +- name: setup configuration file + template: + src: config.json.j2 + dest: /usr/local/etc/shadowsocks-libev/config.json + mode: 0640 + notify: restart-shadowsocks + +- name: enable and start service + command: rcenable shadowsocks-libev + +- name: show client-side config + vars: + config: | + "{" + "server": "{{ ansible_ssh_host }}", + "server_port": {{ shadowsocks.server_port }}, + "local_port": 1080, + "password": "{{ shadowsocks.password }}", + "method": "{{ shadowsocks.method }}", + "timeout": 600, + "fast_open": true, + "reuse_port": true, + "no_delay": true + "}" + debug: + msg: "{{ config.split('\n') }}" diff --git a/roles/shadowsocks/templates/config.json.j2 b/roles/shadowsocks/templates/config.json.j2 new file mode 100644 index 0000000..c5fb0cb --- /dev/null +++ b/roles/shadowsocks/templates/config.json.j2 @@ -0,0 +1,13 @@ +{ + "server": ["::0", "0.0.0.0"], + "server_port": {{ shadowsocks.server_port }}, + "local_port": 1080, + "password": "{{ shadowsocks.password }}", + "method": "{{ shadowsocks.method }}", + "nameserver": "{{ shadowsocks.nameserver }}", + "timeout": 600, + "fast_open": true, + "reuse_port": true, + "no_delay": true, + "user": "nobody" +} -- cgit v1.2.2