tftp: Initial version of tftp server role

Currently this is role allows writing to data directory.
This commit is contained in:
Timo Makinen 2021-03-19 23:49:34 +00:00
parent ec1121107a
commit aa0f0d61dd
2 changed files with 70 additions and 0 deletions

View file

@ -0,0 +1,5 @@
---
- name: restart tftpd
systemd:
name: tftp.socket
state: restarted

65
roles/tftp/tasks/main.yml Normal file
View file

@ -0,0 +1,65 @@
---
- name: install packages
package:
name: tftp-server
state: installed
- name: create group tftpd
group:
name: tftpd
system: true
- name: create user tftpd
user:
name: tftpd
comment: Service TFTP
createhome: false
group: tftpd
home: /var/empty
shell: /sbin/nologin
system: true
- name: set selinxu context for data directory
sefcontext:
path: "/export/tftpboot(/.*)?"
setype: tftpdir_rw_t
- name: create data directory
file:
path: /export/tftpboot
state: directory
mode: 0755
owner: root
group: "{{ ansible_wheel }}"
- name: link data directory
file:
dest: /srv/tftpboot
src: /export/tftpboot
state: link
owner: root
group: "{{ ansible_wheel }}"
follow: false
- name: create drop-in directory for service
file:
path: /etc/systemd/system/tftp.service.d
state: directory
mode: 0755
owner: root
group: "{{ ansible_wheel }}"
- name: create service add-on config
copy:
dest: /etc/systemd/system/tftp.service.d/local.conf
content: |
[Service]
ExecStart=
ExecStart=/usr/sbin/in.tftpd -s /srv/tftpboot -u tftpd -c -v
notify: restart tftpd
- name: enable service
systemd:
name: tftp.socket
enabled: true
state: started