X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=plc.d%2Fnetwork;h=363a0f671402f28ed450cbbefc25ed6abb6d45e5;hb=82d099c7771dd3517bb300552e5b182f49bb27bc;hp=d93f4e89a964195b5240fa98c344d3f0a38af8e0;hpb=7ce915c70c5daba775ce8c723f48830e1e0e22bb;p=myplc.git diff --git a/plc.d/network b/plc.d/network index d93f4e8..363a0f6 100755 --- a/plc.d/network +++ b/plc.d/network @@ -7,8 +7,6 @@ # Mark Huang # Copyright (C) 2006 The Trustees of Princeton University # -# $Id: network,v 1.5 2006/06/23 20:29:22 mlhuang Exp $ -# # Source function library and configuration . /etc/plc.d/functions @@ -17,34 +15,43 @@ # Be verbose set -x +[ "$PLC_HOSTS_ENABLED" -ne 1 ] && exit 0 + case "$1" in start) MESSAGE=$"Generating network files" dialog "$MESSAGE" + mv -f /etc/hosts /etc/hosts_plc.backup + hfile=$(mktemp) # Minimal /etc/hosts - echo "127.0.0.1 localhost.localdomain localhost" >/etc/hosts - ( - for server in DB API BOOT WWW ; do - hostname=PLC_${server}_HOST - ip=PLC_${server}_IP - if [ -n "${!ip}" ] ; then - echo "${!ip} ${!hostname}" - else - ip=$(gethostbyname ${!hostname}) - if [ -n "$ip" ] ; then - echo "$ip ${!hostname}" - fi + for server in DB API BOOT WWW ; do + hostname=PLC_${server}_HOST + ip=PLC_${server}_IP + if [ -n "${!ip}" ] ; then + echo "${!ip} ${!hostname}" + else + ip=$(gethostbyname ${!hostname}) + if [ -n "$ip" ] ; then + echo "$ip ${!hostname}" fi - done - ) >>/etc/hosts + fi + done > $hfile + echo "#generated by /etc/plc.d/network" >/etc/hosts + echo "127.0.0.1 localhost.localdomain localhost" >> /etc/hosts + sort -u $hfile >> /etc/hosts + chmod +r /etc/hosts + rm -f $hfile - # Set up nameservers - ( - [ -n "$PLC_NET_DNS1" ] && echo "nameserver $PLC_NET_DNS1" - [ -n "$PLC_NET_DNS2" ] && echo "nameserver $PLC_NET_DNS2" - ) >/etc/resolv.conf + result "$MESSAGE" + ;; + stop) + MESSAGE=$"Reverting network files" + if [ -f /etc/hosts_plc.backup ] ; then + mv -f /etc/hosts_plc.backup /etc/hosts + fi + dialog "$MESSAGE" result "$MESSAGE" ;; esac