123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- #!/bin/sh /etc/rc.common
- # Copyright (C) 2011 OpenWrt.org
- START=98
- USE_PROCD=1
- PROG=/usr/sbin/ntpd
- HOTPLUG_SCRIPT=/usr/sbin/ntpd-hotplug
- get_dhcp_ntp_servers() {
- local interfaces="$1"
- local filter="*"
- local interface ntpservers ntpserver
- for interface in $interfaces; do
- [ "$filter" = "*" ] && filter="@.interface='$interface'" || filter="$filter,@.interface='$interface'"
- done
- ntpservers=$(ubus call network.interface dump | jsonfilter -e "@.interface[$filter]['data']['ntpserver']")
- for ntpserver in $ntpservers; do
- local duplicate=0
- local entry
- for entry in $server; do
- [ "$ntpserver" = "$entry" ] && duplicate=1
- done
- [ "$duplicate" = 0 ] && server="$server $ntpserver"
- done
- }
- validate_ntp_section() {
- uci_load_validate system timeserver "$1" "$2" \
- 'dhcp_interface:list(string)' \
- 'enable_server:bool:0' \
- 'enabled:bool:1' \
- 'interface:string' \
- 'server:list(host)' \
- 'use_dhcp:bool:1'
- }
- start_ntpd_instance() {
- local peer
- [ "$2" = 0 ] || {
- echo "validation failed"
- return 1
- }
- [ $enabled = 0 ] && return
- [ $use_dhcp = 1 ] && get_dhcp_ntp_servers "$dhcp_interface"
- [ -z "$server" -a "$enable_server" = "0" ] && return
- procd_open_instance
- procd_set_param command "$PROG" -n -N
- if [ "$enable_server" = "1" ]; then
- procd_append_param command -l
- [ -n "$interface" ] && {
- local ifname
- network_get_device ifname "$interface" || \
- ifname="$interface"
- procd_append_param command -I "$ifname"
- procd_append_param netdev "$ifname"
- }
- fi
- [ -x "$HOTPLUG_SCRIPT" ] && procd_append_param command -S "$HOTPLUG_SCRIPT"
- for peer in $server; do
- procd_append_param command -p $peer
- done
- procd_set_param respawn
- [ -x /sbin/ujail -a -e /etc/capabilities/ntpd.json ] && {
- procd_add_jail ntpd ubus
- procd_add_jail_mount "$HOTPLUG_SCRIPT"
- procd_add_jail_mount "/usr/share/libubox/jshn.sh"
- procd_add_jail_mount "/usr/bin/env"
- procd_add_jail_mount "/usr/bin/jshn"
- procd_add_jail_mount "/bin/ubus"
- procd_set_param capabilities /etc/capabilities/ntpd.json
- procd_set_param user ntp
- procd_set_param group ntp
- procd_set_param no_new_privs 1
- }
- procd_close_instance
- }
- start_service() {
- . /lib/functions/network.sh
- validate_ntp_section ntp start_ntpd_instance
- }
- service_triggers() {
- local script name use_dhcp enable_server interface
- script=$(readlink -f "$initscript")
- name=$(basename ${script:-$initscript})
- procd_add_config_trigger "config.change" "system" /etc/init.d/$name reload
- config_load system
- config_get use_dhcp ntp use_dhcp 1
- [ $use_dhcp = 1 ] && {
- local dhcp_interface
- config_get dhcp_interface ntp dhcp_interface
- if [ -n "$dhcp_interface" ]; then
- for n in $dhcp_interface; do
- procd_add_interface_trigger "interface.*" $n /etc/init.d/$name reload
- done
- else
- procd_add_raw_trigger "interface.*" 1000 /etc/init.d/$name reload
- fi
- }
- config_get_bool enable_server ntp enable_server 0
- config_get interface ntp interface
- [ $enable_server -eq 1 ] && [ -n "$interface" ] && {
- local ifname
- network_get_device ifname "$interface" || \
- ifname="$interface"
- procd_add_interface_trigger "interface.*" "$ifname" \
- /etc/init.d/"$name" reload
- }
- procd_add_validation validate_ntp_section
- }
|