summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--dan/ele-dione.yml2
-rw-r--r--dan/ele-helene.yml2
-rw-r--r--inventory/host_vars/ele-dione.yml9
-rw-r--r--inventory/host_vars/ele-helene.yml7
-rw-r--r--inventory/host_vars/lw-dione.yml9
-rw-r--r--inventory/host_vars/lw-helene.yml5
-rw-r--r--roles/chrony/templates/chrony.conf.j255
-rw-r--r--roles/core/ntp/defaults/main.yml (renamed from roles/chrony/defaults/main.yml)18
-rw-r--r--roles/core/ntp/handlers/main.yml (renamed from roles/chrony/handlers/main.yml)0
-rw-r--r--roles/core/ntp/tasks/chrony.yml (renamed from roles/chrony/tasks/main.yml)0
-rw-r--r--roles/core/ntp/tasks/main.yml5
-rw-r--r--roles/core/ntp/templates/chrony.conf.j256
-rw-r--r--spreadspace/lw-dione.yml2
-rw-r--r--spreadspace/lw-helene.yml2
14 files changed, 96 insertions, 76 deletions
diff --git a/dan/ele-dione.yml b/dan/ele-dione.yml
index fe6a0593..742598a8 100644
--- a/dan/ele-dione.yml
+++ b/dan/ele-dione.yml
@@ -7,6 +7,6 @@
- role: core/sshd
- role: core/zsh
- role: core/cpu-microcode
+ - role: core/ntp
- role: core/admin-users
- role: streaming/blackmagic/desktopvideo
- - role: chrony
diff --git a/dan/ele-helene.yml b/dan/ele-helene.yml
index a18477b9..88fae823 100644
--- a/dan/ele-helene.yml
+++ b/dan/ele-helene.yml
@@ -7,9 +7,9 @@
- role: core/sshd
- role: core/zsh
- role: core/cpu-microcode
+ - role: core/ntp
- role: core/admin-users
- role: streaming/blackmagic/desktopvideo
- - role: chrony
post_tasks:
## this is needed for local rtmp proxy
- name: install interface config for guest vlan
diff --git a/inventory/host_vars/ele-dione.yml b/inventory/host_vars/ele-dione.yml
index 1152e5cf..e187f8aa 100644
--- a/inventory/host_vars/ele-dione.yml
+++ b/inventory/host_vars/ele-dione.yml
@@ -39,13 +39,16 @@ kubelet_lvm:
fs: ext4
-chrony_source_pools:
+ntp_variant: chrony
+
+ntp_client:
+ pools:
- name: at.pool.ntp.org
options: iburst
-chrony_hwtimestamp_interfaces:
+ntp_hwtimestamp_interfaces:
- name: "*"
-chrony_server:
+ntp_server:
allow:
- "{{ network_zones.lan.prefix }}"
diff --git a/inventory/host_vars/ele-helene.yml b/inventory/host_vars/ele-helene.yml
index a5418e56..a753a35c 100644
--- a/inventory/host_vars/ele-helene.yml
+++ b/inventory/host_vars/ele-helene.yml
@@ -39,9 +39,12 @@ kubelet_lvm:
fs: ext4
-chrony_source_servers:
+ntp_variant: chrony
+
+ntp_client:
+ servers:
- name: "{{ network_zones.lan.prefix | ipaddr(network_zones.lan.offsets['ele-dione']) | ipaddr('address') }}"
options: iburst minpoll 1 maxpoll 3 polltarget 30
-chrony_hwtimestamp_interfaces:
+ntp_hwtimestamp_interfaces:
- name: "*"
diff --git a/inventory/host_vars/lw-dione.yml b/inventory/host_vars/lw-dione.yml
index 9b05f037..3e38dbd1 100644
--- a/inventory/host_vars/lw-dione.yml
+++ b/inventory/host_vars/lw-dione.yml
@@ -40,13 +40,16 @@ kubelet_lvm:
fs: ext4
-chrony_source_pools:
+ntp_variant: chrony
+
+ntp_client:
+ pools:
- name: at.pool.ntp.org
options: iburst
-chrony_hwtimestamp_interfaces:
+ntp_hwtimestamp_interfaces:
- name: "*"
-chrony_server:
+ntp_server:
allow:
- "192.168.32.0/24"
diff --git a/inventory/host_vars/lw-helene.yml b/inventory/host_vars/lw-helene.yml
index 6b68549b..16c89e76 100644
--- a/inventory/host_vars/lw-helene.yml
+++ b/inventory/host_vars/lw-helene.yml
@@ -40,9 +40,10 @@ kubelet_lvm:
fs: ext4
-chrony_source_servers:
+ntp_client:
+ servers:
- name: "192.168.32.202"
options: iburst minpoll 1 maxpoll 3 polltarget 30
-chrony_hwtimestamp_interfaces:
+ntp_hwtimestamp_interfaces:
- name: "*"
diff --git a/roles/chrony/templates/chrony.conf.j2 b/roles/chrony/templates/chrony.conf.j2
deleted file mode 100644
index 62d45315..00000000
--- a/roles/chrony/templates/chrony.conf.j2
+++ /dev/null
@@ -1,55 +0,0 @@
-### Global options
-
-cmdport 0
-keyfile /etc/chrony/chrony.keys
-driftfile /var/lib/chrony/chrony.drift
-logdir /var/log/chrony
-maxupdateskew 100.0
-rtcsync
-makestep 1 3
-
-{% if chrony_hwtimestamp_interfaces is defined %}
-{% for interface in chrony_hwtimestamp_interfaces %}
-hwtimestamp {{ interface.name }}{% if 'options' in interface %} {{ interface.options }}{% endif %}{{ '' }}
-{% endfor %}
-
-{% endif %}
-
-### Sources
-
-{% if chrony_source_servers is defined %}
-{% for server in chrony_source_servers %}
-server {{ server.name }}{% if 'options' in server %} {{ server.options }}{% endif %}{{ '' }}
-{% endfor %}
-
-{% endif %}
-{% if chrony_source_pools is defined %}
-{% for pool in chrony_source_pools %}
-pool {{ pool.name }}{% if 'options' in pool %} {{ pool.options }}{% endif %}{{ '' }}
-{% endfor %}
-
-{% endif %}
-{% if chrony_source_peers is defined %}
-{% for peer in chrony_source_peers %}
-peer {{ peer.name }}{% if 'options' in peer %} {{ peer.options }}{% endif %}{{ '' }}
-{% endfor %}
-
-{% endif %}
-
-
-{% if chrony_server is defined %}
-### Server
-
-{% for rule in chrony_server.allow | default([]) %}
-allow {{ rule }}
-{% endfor %}
-{% for rule in chrony_server.deny | default([]) %}
-deny {{ rule }}
-{% endfor %}
-{% if 'bindaddress' in chrony_server %}
-bindaddress {{ chrony_server.bind }}
-{% endif %}
-{% if 'port' in chrony_server %}
- port {{ chrony_server.port }}
-{% endif %}
-{% endif %}
diff --git a/roles/chrony/defaults/main.yml b/roles/core/ntp/defaults/main.yml
index bec79d5f..08e0ca80 100644
--- a/roles/chrony/defaults/main.yml
+++ b/roles/core/ntp/defaults/main.yml
@@ -1,23 +1,27 @@
---
-# chrony_source_servers:
+# ntp_variant: systemd-timesyncd
+# ntp_variant: chrony
+# ntp_variant: openntpd
+
+
+# ntp_client:
+# servers:
# - name: ntp.example.com
# options: iburst ...
-
-# chrony_source_pools:
+# pools:
# - name: pool.example.com
# options: iburst ....
-
-# chrony_source_peers:
+# peers:
# - name: peer.example.com
# options: iburst ....
-# chrony_hwtimestamp_interfaces:
+# ntp_hwtimestamp_interfaces:
# - name: "*"
# options: ....
-# chrony_server:
+# ntp_server:
# allow: []
# deny: []
# bind: 0.0.0.0
diff --git a/roles/chrony/handlers/main.yml b/roles/core/ntp/handlers/main.yml
index 08d878be..08d878be 100644
--- a/roles/chrony/handlers/main.yml
+++ b/roles/core/ntp/handlers/main.yml
diff --git a/roles/chrony/tasks/main.yml b/roles/core/ntp/tasks/chrony.yml
index d220af30..d220af30 100644
--- a/roles/chrony/tasks/main.yml
+++ b/roles/core/ntp/tasks/chrony.yml
diff --git a/roles/core/ntp/tasks/main.yml b/roles/core/ntp/tasks/main.yml
new file mode 100644
index 00000000..77f281ff
--- /dev/null
+++ b/roles/core/ntp/tasks/main.yml
@@ -0,0 +1,5 @@
+---
+## TODO: make this work on openbsd and debian/ubuntu
+- name: run ntp-variant specific tasks
+ when: ntp_variant is defined
+ include_tasks: "{{ ntp_variant }}.yml"
diff --git a/roles/core/ntp/templates/chrony.conf.j2 b/roles/core/ntp/templates/chrony.conf.j2
new file mode 100644
index 00000000..0bad9235
--- /dev/null
+++ b/roles/core/ntp/templates/chrony.conf.j2
@@ -0,0 +1,56 @@
+### Global options
+
+cmdport 0
+keyfile /etc/chrony/chrony.keys
+driftfile /var/lib/chrony/chrony.drift
+logdir /var/log/chrony
+maxupdateskew 100.0
+rtcsync
+makestep 1 3
+{% if ntp_hwtimestamp_interfaces is defined %}
+
+{% for interface in ntp_hwtimestamp_interfaces %}
+hwtimestamp {{ interface.name }}{% if 'options' in interface %} {{ interface.options }}{% endif %}{{ '' }}
+{% endfor %}
+{% endif %}
+{% if ntp_client is defined %}
+
+
+### Client
+{% if 'servers' in ntp_client %}
+
+{% for server in ntp_client.servers %}
+server {{ server.name }}{% if 'options' in server %} {{ server.options }}{% endif %}{{ '' }}
+{% endfor %}
+{% endif %}
+{% if 'pools' in ntp_client %}
+
+{% for pool in ntp_client.pools %}
+pool {{ pool.name }}{% if 'options' in pool %} {{ pool.options }}{% endif %}{{ '' }}
+{% endfor %}
+{% endif %}
+{% if 'peers' in ntp_client %}
+
+{% for peer in ntp_client.peers %}
+peer {{ peer.name }}{% if 'options' in peer %} {{ peer.options }}{% endif %}{{ '' }}
+{% endfor %}
+{% endif %}
+{% endif %}
+{% if ntp_server is defined %}
+
+
+### Server
+
+{% for rule in ntp_server.allow | default([]) %}
+allow {{ rule }}
+{% endfor %}
+{% for rule in ntp_server.deny | default([]) %}
+deny {{ rule }}
+{% endfor %}
+{% if 'bindaddress' in ntp_server %}
+bindaddress {{ ntp_server.bind }}
+{% endif %}
+{% if 'port' in ntp_server %}
+ port {{ ntp_server.port }}
+{% endif %}
+{% endif %}
diff --git a/spreadspace/lw-dione.yml b/spreadspace/lw-dione.yml
index f0a3ce59..edc2e97b 100644
--- a/spreadspace/lw-dione.yml
+++ b/spreadspace/lw-dione.yml
@@ -7,6 +7,6 @@
- role: core/sshd
- role: core/zsh
- role: core/cpu-microcode
+ - role: core/ntp
- role: core/admin-users
- role: streaming/blackmagic/desktopvideo
- - role: chrony
diff --git a/spreadspace/lw-helene.yml b/spreadspace/lw-helene.yml
index 5b2afda3..cbf9f3b9 100644
--- a/spreadspace/lw-helene.yml
+++ b/spreadspace/lw-helene.yml
@@ -7,6 +7,6 @@
- role: core/sshd
- role: core/zsh
- role: core/cpu-microcode
+ - role: core/ntp
- role: core/admin-users
- role: streaming/blackmagic/desktopvideo
- - role: chrony