Makefile.yp revision 1.10
11.10Sitojun# $NetBSD: Makefile.yp,v 1.10 2000/07/30 02:33:13 itojun Exp $ 21.1Sthorpej# 31.1Sthorpej# This is the YP Makefile, used to create and push YP maps. 41.1Sthorpej# 51.1Sthorpej 61.5Slukem# Invoke with NOPUSH != "" to prevent the maps from being yppushed upon rebuild 71.5Slukem# 81.5SlukemNOPUSH?= "" 91.5Slukem 101.5Slukem# Password maps in standard YP are insecure, because the pw_passwd 111.5Slukem# field is accessable by any user. FreeBSD, NetBSD and OpenBSD have 121.5Slukem# a common solution: a secure map (generated with makedbm -s) can 131.5Slukem# only be accessed by a client bound to a privileged port. 141.5Slukem# 151.8Slukem# Uncomment out the following if you need compatibility with 161.8Slukem# sites that don't support this feature. 171.7Slukem# 181.8Slukem#INSECURE?= yes 191.5Slukem 201.5Slukem 211.5SlukemYPDBDIR= /var/yp 221.5SlukemDIR= /etc 231.5SlukemAMDDIR= /etc/amd 241.5SlukemDOMAIN= "`/usr/bin/basename ${.CURDIR}`" 251.5Slukem 261.5SlukemAWK= /usr/bin/awk 271.5SlukemCAT= /bin/cat 281.5SlukemCP= /bin/cp 291.5SlukemCUT= /usr/bin/cut 301.5SlukemECHO= /bin/echo 311.5SlukemMAKEDBM= /usr/sbin/makedbm 321.5SlukemMAKEDBM_S= ${MAKEDBM} -s 331.5SlukemMKALIAS= /usr/sbin/mkalias 341.5SlukemMKNETID= /usr/sbin/mknetid 351.5SlukemREVNETGROUP= /usr/sbin/revnetgroup 361.5SlukemRM= /bin/rm 371.5SlukemSED= /usr/bin/sed 381.5SlukemSENDMAIL= /usr/sbin/sendmail 391.9SabsSORT= /usr/bin/sort 401.5SlukemSTDETHERS= /usr/sbin/stdethers 411.5SlukemSTDHOSTS= /usr/sbin/stdhosts 421.5SlukemTOUCH= /usr/bin/touch 431.5SlukemYPPUSH= /usr/sbin/yppush 441.5Slukem 451.1Sthorpej 461.2Sthorpej# We have a rule for ypservers, but we don't build it by default, since 471.2Sthorpej# it seldom changes (only when slaves are added/deleted). 481.2Sthorpej 491.10Sitojunall: passwd aliases amd.home ethers group hosts ipnodes netgroup networks rpc services protocols netid 501.5Slukem 511.5Slukem 521.5Slukempasswd.time: ${DIR}/master.passwd 531.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 541.5Slukem umask 077 ; \ 551.5Slukem if [ "${INSECURE}" != "yes" ]; then \ 561.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 | \ 571.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 581.5Slukem { print $$1, $$1":*:"$$3":"$$4":"$$5":"$$6":"$$7 }' -|\ 591.9Sabs ${SORT} | ${MAKEDBM} - passwd.byname; \ 601.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 |\ 611.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 621.5Slukem { print $$3, $$1":*:"$$3":"$$4":"$$5":"$$6":"$$7 }' -|\ 631.9Sabs ${SORT} | ${MAKEDBM} - passwd.byuid; \ 641.5Slukem else \ 651.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 | \ 661.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 671.9Sabs { print $$1, $$0 }' - | ${SORT} | \ 681.9Sabs ${MAKEDBM} - passwd.byname; \ 691.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 |\ 701.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 711.9Sabs { print $$3, $$0 }' - | ${SORT} | \ 721.9Sabs ${MAKEDBM} - passwd.byuid; \ 731.5Slukem fi; \ 741.5Slukem ${CAT} ${.ALLSRC} | \ 751.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 761.9Sabs { print $$1, $$0 }' - | ${SORT} | \ 771.9Sabs ${MAKEDBM_S} - master.passwd.byname; \ 781.5Slukem ${CAT} ${.ALLSRC} | \ 791.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 801.9Sabs { print $$3, $$0 }' - | ${SORT} | \ 811.9Sabs ${MAKEDBM_S} - master.passwd.byuid; \ 821.5Slukem ${TOUCH} ${.TARGET}; \ 831.5Slukem ${ECHO} "updated passwd"; \ 841.5Slukem if [ ! ${NOPUSH} ]; then \ 851.5Slukem ${YPPUSH} -d ${DOMAIN} passwd.byname; \ 861.5Slukem ${YPPUSH} -d ${DOMAIN} passwd.byuid; \ 871.5Slukem ${YPPUSH} -d ${DOMAIN} master.passwd.byname; \ 881.5Slukem ${YPPUSH} -d ${DOMAIN} master.passwd.byuid; \ 891.5Slukem ${ECHO} "pushed passwd"; \ 901.5Slukem else \ 911.5Slukem : ; \ 921.5Slukem fi \ 931.5Slukem else \ 941.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 951.5Slukem fi 961.5Slukem 971.5Slukem 981.5Slukemaliases.time: ${DIR}/aliases 991.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1001.5Slukem ${CP} -p ${.ALLSRC} ${DOMAIN}-aliases; \ 1011.5Slukem ${SENDMAIL} -bi -oA${PWD}/${DOMAIN}-aliases; \ 1021.9Sabs ${MAKEDBM} -u ${DOMAIN}-aliases | ${SORT} | \ 1031.9Sabs ${MAKEDBM} - mail.aliases; \ 1041.5Slukem ${MKALIAS} mail.aliases mail.byaddr; \ 1051.5Slukem ${TOUCH} ${.TARGET}; \ 1061.5Slukem ${RM} ${DOMAIN}-aliases.db ${DOMAIN}-aliases; \ 1071.5Slukem ${ECHO} "updated aliases"; \ 1081.5Slukem if [ ! ${NOPUSH} ]; then \ 1091.5Slukem ${YPPUSH} -d ${DOMAIN} mail.aliases; \ 1101.5Slukem ${YPPUSH} -d ${DOMAIN} mail.byaddr; \ 1111.5Slukem ${ECHO} "pushed aliases"; \ 1121.5Slukem else \ 1131.5Slukem : ; \ 1141.5Slukem fi \ 1151.5Slukem else \ 1161.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1171.5Slukem fi 1181.5Slukem 1191.1Sthorpej 1201.5Slukemamd.home.time: ${AMDDIR}/amd.home 1211.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1221.5Slukem ${SED} -e "s/#.*$$//" -e "/^$$/d" ${.ALLSRC} | \ 1231.5Slukem ${AWK} '{ \ 1241.5Slukem for (i = 1; i <= NF; i++) \ 1251.5Slukem if (i == NF) { \ 1261.5Slukem if (substr($$i, length($$i), 1) == "\\") { \ 1271.5Slukem printf("%s", \ 1281.5Slukem substr($$i, 1, length($$i) - 1)); \ 1291.5Slukem } \ 1301.5Slukem else \ 1311.5Slukem printf("%s\n", $$i); \ 1321.5Slukem } \ 1331.5Slukem else \ 1341.5Slukem printf("%s ", $$i); \ 1351.5Slukem }' | \ 1361.9Sabs ${SORT} | ${MAKEDBM} - amd.home; \ 1371.5Slukem ${TOUCH} ${.TARGET}; \ 1381.5Slukem ${ECHO} "updated amd.home"; \ 1391.5Slukem if [ ! ${NOPUSH} ]; then \ 1401.5Slukem ${YPPUSH} -d ${DOMAIN} amd.home; \ 1411.5Slukem ${ECHO} "pushed amd.home"; \ 1421.1Sthorpej else \ 1431.1Sthorpej : ; \ 1441.1Sthorpej fi \ 1451.1Sthorpej else \ 1461.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1471.1Sthorpej fi 1481.1Sthorpej 1491.1Sthorpej 1501.5Slukemethers.time: ${DIR}/ethers 1511.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1521.5Slukem ${STDETHERS} ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 1531.5Slukem ${AWK} 'BEGIN { FS="\t"; OFS="\t"; } { print $$1, $$0 }' | \ 1541.9Sabs ${SORT} | ${MAKEDBM} - ethers.byaddr; \ 1551.5Slukem ${STDETHERS} ${.ALLSRC} | \ 1561.5Slukem ${AWK} 'BEGIN { FS="\t"; OFS="\t"; } { print $$2, $$0 }' | \ 1571.9Sabs ${SORT} | ${MAKEDBM} - ethers.byname; \ 1581.5Slukem ${TOUCH} ${.TARGET}; \ 1591.5Slukem ${ECHO} "updated ethers"; \ 1601.5Slukem if [ ! ${NOPUSH} ]; then \ 1611.5Slukem ${YPPUSH} -d ${DOMAIN} ethers.byaddr; \ 1621.5Slukem ${YPPUSH} -d ${DOMAIN} ethers.byname; \ 1631.5Slukem ${ECHO} "pushed ethers"; \ 1641.1Sthorpej else \ 1651.1Sthorpej : ; \ 1661.1Sthorpej fi \ 1671.1Sthorpej else \ 1681.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1691.1Sthorpej fi 1701.1Sthorpej 1711.5Slukem 1721.5Slukemgroup.time: ${DIR}/group 1731.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1741.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1751.5Slukem { print $$1, $$0 }' ${.ALLSRC} | \ 1761.9Sabs ${SORT} | ${MAKEDBM} - group.byname; \ 1771.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1781.5Slukem { print $$3, $$0 }' ${.ALLSRC} | \ 1791.9Sabs ${SORT} | ${MAKEDBM} - group.bygid; \ 1801.5Slukem ${TOUCH} ${.TARGET}; \ 1811.5Slukem ${ECHO} "updated group"; \ 1821.5Slukem if [ ! ${NOPUSH} ]; then \ 1831.5Slukem ${YPPUSH} -d ${DOMAIN} group.byname; \ 1841.5Slukem ${YPPUSH} -d ${DOMAIN} group.bygid; \ 1851.5Slukem ${ECHO} "pushed group"; \ 1861.1Sthorpej else \ 1871.1Sthorpej : ; \ 1881.1Sthorpej fi \ 1891.1Sthorpej else \ 1901.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1911.1Sthorpej fi 1921.1Sthorpej 1931.5Slukem 1941.10Sitojun# Solaris 8 does the following: 1951.10Sitojun# - /etc/hosts and hosts.{byname,byaddr} are IPv4 only. 1961.10Sitojun# - /etc/inet/ipnodes and ipnodes.{byname,byaddr} are used for protocol 1971.10Sitojun# independent name-to-address mapping. 1981.10Sitojun# 1991.10Sitojun# For local name resolution, we made /etc/hosts protocol independent. 2001.10Sitojun# For NIS name resolution, we obey Solaris 8 practice. 2011.10Sitojun# - We keep hosts.{byname,byaddr} IPv4 only, to be friendly with Solaris 8 2021.10Sitojun# clients. 2031.10Sitojun# - ipnodes.{byname,byaddr} is used for protocol independent mapping. 2041.10Sitojun# We generate all the mappings from /etc/hosts, for compatibility with NetBSD 2051.10Sitojun# local name resolution. 2061.10Sitojun# 2071.5Slukemhosts.time: ${DIR}/hosts 2081.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2091.5Slukem ${STDHOSTS} ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 2101.5Slukem ${AWK} '{for (i = 2; i <= NF; i++) print $$i, $$0 }' | \ 2111.9Sabs ${SORT} | ${MAKEDBM} - hosts.byname; \ 2121.5Slukem ${STDHOSTS} ${.ALLSRC} | \ 2131.5Slukem ${AWK} 'BEGIN { OFS="\t"; } { print $$1, $$0 }' | \ 2141.9Sabs ${SORT} | ${MAKEDBM} - hosts.byaddr; \ 2151.5Slukem ${TOUCH} ${.TARGET}; \ 2161.5Slukem ${ECHO} "updated hosts"; \ 2171.5Slukem if [ ! ${NOPUSH} ]; then \ 2181.5Slukem ${YPPUSH} -d ${DOMAIN} hosts.byname; \ 2191.5Slukem ${YPPUSH} -d ${DOMAIN} hosts.byaddr; \ 2201.5Slukem ${ECHO} "pushed hosts"; \ 2211.1Sthorpej else \ 2221.1Sthorpej : ; \ 2231.1Sthorpej fi \ 2241.1Sthorpej else \ 2251.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2261.1Sthorpej fi 2271.1Sthorpej 2281.5Slukem 2291.10Sitojunipnodes.time: ${DIR}/hosts 2301.10Sitojun -@if [ -f ${.ALLSRC} ]; then \ 2311.10Sitojun ${STDHOSTS} -n ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 2321.10Sitojun ${AWK} '{for (i = 2; i <= NF; i++) print $$i, $$0 }' | \ 2331.10Sitojun ${SORT} | ${MAKEDBM} - ipnodes.byname; \ 2341.10Sitojun ${STDHOSTS} -n ${.ALLSRC} | \ 2351.10Sitojun ${AWK} 'BEGIN { OFS="\t"; } { print $$1, $$0 }' | \ 2361.10Sitojun ${SORT} | ${MAKEDBM} - ipnodes.byaddr; \ 2371.10Sitojun ${TOUCH} ${.TARGET}; \ 2381.10Sitojun ${ECHO} "updated ipnodes"; \ 2391.10Sitojun if [ ! ${NOPUSH} ]; then \ 2401.10Sitojun ${YPPUSH} -d ${DOMAIN} ipnodes.byname; \ 2411.10Sitojun ${YPPUSH} -d ${DOMAIN} ipnodes.byaddr; \ 2421.10Sitojun ${ECHO} "pushed ipnodes"; \ 2431.10Sitojun else \ 2441.10Sitojun : ; \ 2451.10Sitojun fi \ 2461.10Sitojun else \ 2471.10Sitojun ${ECHO} "couldn't find ${.ALLSRC}"; \ 2481.10Sitojun fi 2491.10Sitojun 2501.10Sitojun 2511.5Slukemnetgroup.time: ${DIR}/netgroup 2521.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2531.9Sabs ${CAT} ${.ALLSRC} | ${SORT} | ${MAKEDBM} - netgroup; \ 2541.5Slukem ${CAT} ${.ALLSRC} | ${REVNETGROUP} -u -f - | \ 2551.9Sabs ${SORT} | ${MAKEDBM} - netgroup.byuser; \ 2561.5Slukem ${CAT} ${.ALLSRC} | ${REVNETGROUP} -h -f - | \ 2571.9Sabs ${SORT} | ${MAKEDBM} - netgroup.byhost; \ 2581.5Slukem ${TOUCH} ${.TARGET}; \ 2591.5Slukem ${ECHO} "updated netgroup"; \ 2601.5Slukem if [ ! ${NOPUSH} ]; then \ 2611.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup; \ 2621.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup.byuser; \ 2631.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup.byhost; \ 2641.5Slukem ${ECHO} "pushed netgroup"; \ 2651.1Sthorpej else \ 2661.1Sthorpej : ; \ 2671.1Sthorpej fi \ 2681.1Sthorpej else \ 2691.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2701.1Sthorpej fi 2711.1Sthorpej 2721.5Slukem 2731.5Slukemnetworks.time: ${DIR}/networks 2741.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2751.5Slukem ${SED} -e "/^#/d" -e s/#.*$$// ${.ALLSRC} | \ 2761.5Slukem ${AWK} '{print $$1, $$0; \ 2771.5Slukem for (i = 3;i <= NF;i++) print $$i,$$0}' | \ 2781.9Sabs ${SORT} | ${MAKEDBM} - networks.byname; \ 2791.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 2801.5Slukem ${.ALLSRC} | \ 2811.9Sabs ${SORT} | ${MAKEDBM} - networks.byaddr; \ 2821.5Slukem ${TOUCH} ${.TARGET}; \ 2831.5Slukem ${ECHO} "updated networks"; \ 2841.5Slukem if [ ! ${NOPUSH} ]; then \ 2851.5Slukem ${YPPUSH} -d ${DOMAIN} networks.byname; \ 2861.5Slukem ${YPPUSH} -d ${DOMAIN} networks.byaddr; \ 2871.5Slukem ${ECHO} "pushed networks"; \ 2881.1Sthorpej else \ 2891.1Sthorpej : ; \ 2901.1Sthorpej fi \ 2911.1Sthorpej else \ 2921.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2931.1Sthorpej fi 2941.1Sthorpej 2951.1Sthorpej 2961.5Slukemprotocols.time: ${DIR}/protocols 2971.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2981.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 2991.5Slukem ${.ALLSRC} | \ 3001.9Sabs ${SORT} | ${MAKEDBM} - protocols.bynumber; \ 3011.5Slukem ${SED} -e "/^#/d" -e s/#.*$$// ${.ALLSRC} | \ 3021.5Slukem ${AWK} '{print $$1, $$0; \ 3031.5Slukem for (i = 3;i <= NF;i++) print $$i,$$0}' | \ 3041.9Sabs ${SORT} | ${MAKEDBM} - protocols.byname; \ 3051.5Slukem ${TOUCH} ${.TARGET}; \ 3061.5Slukem ${ECHO} "updated protocols"; \ 3071.5Slukem if [ ! ${NOPUSH} ]; then \ 3081.5Slukem ${YPPUSH} -d ${DOMAIN} protocols.bynumber; \ 3091.5Slukem ${YPPUSH} -d ${DOMAIN} protocols.byname; \ 3101.5Slukem ${ECHO} "pushed protocols"; \ 3111.1Sthorpej else \ 3121.1Sthorpej : ; \ 3131.1Sthorpej fi \ 3141.1Sthorpej else \ 3151.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3161.1Sthorpej fi 3171.1Sthorpej 3181.1Sthorpej 3191.5Slukemrpc.time: ${DIR}/rpc 3201.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3211.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3221.5Slukem ${.ALLSRC} | \ 3231.9Sabs ${SORT} | ${MAKEDBM} - rpc.bynumber; \ 3241.5Slukem ${TOUCH} ${.TARGET}; \ 3251.5Slukem ${ECHO} "updated rpc"; \ 3261.5Slukem if [ ! ${NOPUSH} ]; then \ 3271.5Slukem ${YPPUSH} -d ${DOMAIN} rpc.bynumber; \ 3281.5Slukem ${ECHO} "pushed rpc"; \ 3291.1Sthorpej else \ 3301.1Sthorpej : ; \ 3311.1Sthorpej fi \ 3321.1Sthorpej else \ 3331.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3341.1Sthorpej fi 3351.1Sthorpej 3361.1Sthorpej 3371.5Slukemservices.time: ${DIR}/services 3381.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3391.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3401.5Slukem ${.ALLSRC} | \ 3411.9Sabs ${SORT} | ${MAKEDBM} - services.byname; \ 3421.5Slukem ${TOUCH} ${.TARGET}; \ 3431.5Slukem ${ECHO} "updated services"; \ 3441.5Slukem if [ ! ${NOPUSH} ]; then \ 3451.5Slukem ${YPPUSH} -d ${DOMAIN} services.byname; \ 3461.5Slukem ${ECHO} "pushed services"; \ 3471.5Slukem else \ 3481.5Slukem : ; \ 3491.5Slukem fi \ 3501.5Slukem else \ 3511.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3521.5Slukem fi 3531.5Slukem 3541.5Slukem 3551.5Slukemnetid.time: ${DIR}/passwd ${DIR}/group ${DIR}/hosts ${DIR}/netid 3561.5Slukem -@${MKNETID} -q -d ${DOMAIN} -p ${DIR}/passwd -g ${DIR}/group -h \ 3571.5Slukem ${DIR}/hosts -m ${DIR}/netid | \ 3581.9Sabs ${SORT} | ${MAKEDBM} - netid.byname; \ 3591.5Slukem ${TOUCH} ${.TARGET}; \ 3601.5Slukem ${ECHO} "updated netid"; \ 3611.5Slukem if [ ! ${NOPUSH} ]; then \ 3621.5Slukem ${YPPUSH} -d ${DOMAIN} netid.byname; \ 3631.5Slukem ${ECHO} "pushed netid"; \ 3641.1Sthorpej else \ 3651.1Sthorpej : ; \ 3661.1Sthorpej fi 3671.1Sthorpej 3681.5Slukem 3691.6Slukemypservers.time: ${.CURDIR}/ypservers 3701.6Slukem -@${MAKEDBM} ypservers ypservers; \ 3711.6Slukem ${TOUCH} ${.TARGET}; \ 3721.5Slukem ${ECHO} "updated ypservers"; \ 3731.5Slukem if [ ! ${NOPUSH} ]; then \ 3741.5Slukem ${YPPUSH} -d ${DOMAIN} ypservers; \ 3751.5Slukem ${ECHO} "pushed ypservers"; \ 3761.2Sthorpej else \ 3771.2Sthorpej : ; \ 3781.2Sthorpej fi 3791.1Sthorpej 3801.5Slukem 3811.1Sthorpejpasswd: passwd.time 3821.1Sthorpejgroup: group.time 3831.1Sthorpejhosts: hosts.time 3841.10Sitojunipnodes: ipnodes.time 3851.5Slukemaliases: aliases.time 3861.5Slukemamd.home: amd.home.time 3871.1Sthorpejethers: ethers.time 3881.5Slukemnetgroup: netgroup.time 3891.1Sthorpejnetworks: networks.time 3901.1Sthorpejrpc: rpc.time 3911.1Sthorpejservices: services.time 3921.1Sthorpejprotocols: protocols.time 3931.1Sthorpejnetid: netid.time 3941.6Slukemypservers: ypservers.time 3951.5Slukem 3961.5Slukem${DIR}/passwd: 3971.5Slukem${DIR}/group: 3981.5Slukem${DIR}/hosts: 3991.5Slukem${DIR}/aliases: 4001.5Slukem${AMDDIR}/amd.home: 4011.5Slukem${DIR}/ethers: 4021.5Slukem${DIR}/master.passwd: 4031.5Slukem${DIR}/netgroup: 4041.5Slukem${DIR}/networks: 4051.5Slukem${DIR}/rpc: 4061.5Slukem${DIR}/services: 4071.5Slukem${DIR}/protocols: 4081.5Slukem${DIR}/netid: 409