#!/bin/sh # This file was originally created automatically as part of default NTP application installation from debian package. # This is now manually modified for supporting NTP in management VRF. # When management VRF is enabled, the NTP application should be started using "ip vrf exec mgmt". # Check has been added to verify the management VRF enabled status and use "ip vrf exec mgmt" when it is enabled. # This file will be copied to /usr/libexec/ntpsec/ntp-systemd-wrapper file that gets created during build process. DAEMON=/usr/sbin/ntpd PIDFILE=/run/ntpd.pid LOCKFILE=/run/lock/ntpsec-ntpdate if [ -r /etc/default/ntpsec ]; then . /etc/default/ntpsec fi if [ "$IGNORE_DHCP" != "yes" ] && [ -e /run/ntpsec/ntp.conf.dhcp ]; then NTPD_OPTS="$NTPD_OPTS -c /run/ntpsec/ntp.conf.dhcp" else # List the default -c first, so if the admin has specified -c in # NTPD_OPTS, it is honored. NTPD_OPTS="-c /etc/ntpsec/ntp.conf $NTPD_OPTS" fi NTPD_OPTS="$NTPD_OPTS -u ntpsec:ntpsec" # Protect the service startup against concurrent ntpdate ifup hooks ( if flock -w 180 9; then # when mgmt vrf is configured, ntp starts in mgmt vrf by default unless user configures otherwise vrfEnabled=$(/usr/local/bin/sonic-cfggen -d -v 'MGMT_VRF_CONFIG["vrf_global"]["mgmtVrfEnabled"]' 2> /dev/null) vrfConfigured=$(/usr/local/bin/sonic-cfggen -d -v 'NTP["global"]["vrf"]' 2> /dev/null) if [ "$vrfEnabled" = "true" ] then if [ "$vrfConfigured" = "default" ] then echo "Starting NTP server in default-vrf for default set as NTP vrf" exec $DAEMON -p $PIDFILE $NTPD_OPTS else echo "Starting NTP server in mgmt-vrf" exec ip vrf exec mgmt $DAEMON -p $PIDFILE $NTPD_OPTS fi else echo "Starting NTP server in default-vrf" exec $DAEMON -p $PIDFILE $NTPD_OPTS fi else echo "Timeout waiting for $LOCKFILE" exit 1 fi ) 9>$LOCKFILE