blob: 5adaf18880ac941491bbf62e624c9d3def147b87 (
plain)
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
|
- name: "check radicle_node_version"
shell: |
[ "{{ radicle_node_version }}" = "1" ] || \
(echo "Unexpected version {{ radicle_node_version }}" 1>&2; exit 1)
- name: "check that radicle_node_key is set"
shell: |
echo radicle_node_key Ansible variable is not set
exit 1
when: radicle_node_key is not defined
- name: "check that radicle_node_key_pub is set"
shell: |
echo radicle_node_key_pub Ansible variable is not set
exit 1
when: radicle_node_key_pub is not defined
- name: "install important additional packages for Radicle"
apt:
name:
# For the Radicle installer
- curl
# Radicle is built on git.
- git
# Rsync for backups.
- rsync
- name: "create directory for Radicle keys"
file:
state: directory
path: /home/_rad/.radicle/keys
owner: _rad
group: _rad
mode: 0755
- name: "install Radicle private key"
copy:
content: "{{ radicle_node_key }}"
dest: /home/_rad/.radicle/keys/radicle
owner: _rad
group: _rad
mode: 0600
- name: "install Radicle public key"
copy:
content: "{{ radicle_node_key_pub }}"
dest: /home/_rad/.radicle/keys/radicle.pub
owner: _rad
group: _rad
mode: 0644
- name: "install of upgrade Radicle using installer"
shell: |
# Can't use "set -o pipefail" here, because shell may not be
# bash. So we don't use a pipe from curl to bash, and download
# as one command and run script as a second command. If the
# download fails, the task fails.
curl -sSf https://radicle.xyz/install > radicle-install
sudo -u _rad bash radicle-install
- name: "install systemd unit for Radicle node"
copy:
content: |
[Unit]
After=syslog.target network.target
Description=Radicle Node
[Service]
Type=simple
ExecStart=/home/_rad/.radicle/bin/radicle-node --listen 0.0.0.0:8776
Environment=RAD_HOME=/home/_rad/.radicle
KillMode=process
Restart=never
RestartSec=1
User=_rad
Group=_rad
[Install]
WantedBy=default.target
dest: /lib/systemd/system/radicle-node.service
- name: "start systemd unit for Radicle node"
systemd:
name: radicle-node
state: restarted
masked: no
enabled: yes
daemon_reload: yes
# Ansible does not seem to always actually start the unit, so do
# it manually. This seems to only happen on the first run on a
# freshly created host.
- name: "actually start node"
shell: |
systemctl restart radicle-node
systemctl status radicle-node
- name: "connect to other Radicle nodes"
when: radicle_node_connections is defined
with_items: "{{ radicle_node_connections }}"
shell: |
cat <<'EOF' > connect.sh
export PATH="$HOME/.radicle/bin:$PATH"
rad node status
rad node connect "{{ item.nid }}@{{ item.host }}:{{ item.port }}"
EOF
sudo -u _rad bash -ex connect.sh
- name: "seed Radicle repositories"
when: radicle_node_repositories is defined
with_items: "{{ radicle_node_repositories }}"
shell: |
cat <<'EOF' > seed.sh
export PATH="$HOME/.radicle/bin:$PATH"
rad node status
rad seed "{{ item.rid }}"
EOF
sudo -u _rad bash -ex seed.sh
|