forked from nephoscale/cloudscript
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathopenvpn.cloudscript
More file actions
161 lines (119 loc) · 5.37 KB
/
openvpn.cloudscript
File metadata and controls
161 lines (119 loc) · 5.37 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
cloudscript openvpn_multi_stack
version = _latest
result_template = openvpn_pair_result_tmpl
globals
server_password = lib::random_password()
console_password = lib::random_password()
openvpn_slice_user = 'openvpn'
thread openvpn_setup
tasks = [openvpn_server_client_setup]
task openvpn_server_client_setup
#-----------------------
# Keys
#-----------------------
/key/password openvpn_server_pass_key read_or_create
key_group = _SERVER
password = server_password
/key/password openvpn_server_console_key read_or_create
key_group = _CONSOLE
password = console_password
# create storage slice keys
/key/token openvpn_slice_key read_or_create
username = openvpn_slice_user
#-------------------------------
# create openvpn bootstrap
#-------------------------------
# create slice to store script in cloudstorage
/storage/slice openvpn_slice read_or_create
keys = [openvpn_slice_key]
# create slice container to store script in cloudstorage
/storage/container openvpn_container read_or_create
slice = openvpn_slice
# place script data in cloudstorage
/storage/object openvpn_server_script_object => [openvpn_slice] read_or_create
container_name = 'openvpn_container'
file_name = 'openvpn_server_script.sh'
slice = openvpn_slice
content_data = openvpn_server_script_tmpl
# associate the cloudstorage object with the openvpn script
/orchestration/script openvpn_server_script => [openvpn_slice, openvpn_container, openvpn_server_script_object] read_or_create
data_uri = 'cloudstorage://openvpn_slice/openvpn_container/openvpn_server_script.sh'
script_type = _shell
encoding = _storage
# place script data in cloudstorage
/storage/object openvpn_client_script_object => [openvpn_slice, openvpn_server] read_or_create
container_name = 'openvpn_container'
file_name = 'openvpn_client_script.sh'
slice = openvpn_slice
content_data = openvpn_client_script_tmpl
b64decode = 0
# associate the cloudstorage object with the openvpn script
/orchestration/script openvpn_client_script => [openvpn_slice, openvpn_container, openvpn_client_script_object] read_or_create
data_uri = 'cloudstorage://openvpn_slice/openvpn_container/openvpn_client_script.sh'
script_type = _shell
encoding = _storage
#-------------------------------
# create openvpn server recipe
#-------------------------------
/orchestration/recipe openvpn_server_recipe read_or_create
scripts = [openvpn_server_script]
/orchestration/recipe openvpn_client_recipe read_or_create
scripts = [openvpn_client_script]
#-----------------------
# Cloud Servers
#-----------------------
/server/cloud openvpn_server read_or_create
hostname = 'openvpn-server'
image = 'Linux Ubuntu Server 10.04 LTS 64-bit'
service_type = 'CS1'
keys = [openvpn_server_pass_key, openvpn_server_console_key]
recipes = [openvpn_server_recipe]
/server/cloud openvpn_client read_or_create
hostname = 'openvpn-client'
image = 'Linux Ubuntu Server 10.04 LTS 64-bit'
service_type = 'CS1'
keys = [openvpn_server_pass_key, openvpn_server_console_key]
recipes = [openvpn_client_recipe]
text_template openvpn_server_script_tmpl
#!/bin/bash
apt-get install -y openvpn gadmin-openvpn-server bridge-utils > /dev/null
# Generate a static key
cd /etc/openvpn
openvpn --genkey --secret static.key > /dev/null
# set a cloudscript variable to key contents so it may be retrieved by client during client setup.
SERVER_KEY="`cat static.key`"
# Server configuration file
echo '
dev tun
ifconfig 172.16.0.1 172.16.0.2
secret static.key
' > /etc/openvpn/server.conf
/etc/init.d/openvpn start > /dev/null
# only output/echo JSON so it can be processed by cloudscript <*>.results.server_key
echo "{ \"server_key\":\"$SERVER_KEY\" }"
_eof
text_template openvpn_client_script_tmpl
#!/bin/bash
apt-get install -y openvpn gadmin-openvpn-client
echo '
remote {{ openvpn_server.ipaddress_private }}
dev tun
ifconfig 172.16.0.2 172.16.0.1
secret static.key
' > /etc/openvpn/client.conf
# Retrieve static key from cloudscript variable
echo "{{ openvpn_server.results.server_key }}" > /etc/openvpn/static.key
chmod 0600 /etc/openvpn/static.key
echo "Run '/usr/sbin/gadmin-openvpn-server' for GUI admin tool to configure and manage OpenVPN server."
echo "Run '/usr/sbin/gadmin-openvpn-client' for GUI admin tool to configure and manage OpenVPN client."
/etc/init.d/openvpn start
_eof
text_template openvpn_pair_result_tmpl
Thank you for provisioning a openvpn server/client setup.
You can login to the server server directly via SSH by connecting
to root@{{ openvpn_server.ipaddress_public }} using the password:
{{ openvpn_server_pass_key.password }}
You can login to the openvpn client directly via SSH by connecting
to root@{{ openvpn_client.ipaddress_public }} using the password:
{{ openvpn_server_pass_key.password }}
_eof