Makefile.yp revision 1.17
11.17Shubertf# $NetBSD: Makefile.yp,v 1.17 2001/08/05 12:40:15 hubertf 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.15Swiz# field is accessible 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.11Schristos# In addition, by adding shadow to the list of rules we support 211.11Schristos# linux and solaris type shadow maps. 221.5Slukem 231.5SlukemYPDBDIR= /var/yp 241.5SlukemDIR= /etc 251.5SlukemAMDDIR= /etc/amd 261.17ShubertfAMDMAPS= amd.home 271.17ShubertfDOMAIN= ${.CURDIR:T} 281.5Slukem 291.5SlukemAWK= /usr/bin/awk 301.5SlukemCAT= /bin/cat 311.5SlukemCP= /bin/cp 321.5SlukemCUT= /usr/bin/cut 331.5SlukemECHO= /bin/echo 341.5SlukemMAKEDBM= /usr/sbin/makedbm 351.5SlukemMAKEDBM_S= ${MAKEDBM} -s 361.5SlukemMKALIAS= /usr/sbin/mkalias 371.5SlukemMKNETID= /usr/sbin/mknetid 381.5SlukemREVNETGROUP= /usr/sbin/revnetgroup 391.5SlukemRM= /bin/rm 401.5SlukemSED= /usr/bin/sed 411.5SlukemSENDMAIL= /usr/sbin/sendmail 421.9SabsSORT= /usr/bin/sort 431.5SlukemSTDETHERS= /usr/sbin/stdethers 441.5SlukemSTDHOSTS= /usr/sbin/stdhosts 451.5SlukemTOUCH= /usr/bin/touch 461.5SlukemYPPUSH= /usr/sbin/yppush 471.5Slukem 481.1Sthorpej 491.2Sthorpej# We have a rule for ypservers, but we don't build it by default, since 501.2Sthorpej# it seldom changes (only when slaves are added/deleted). 511.2Sthorpej 521.17Shubertfall: passwd aliases ${AMDMAPS} ethers group hosts ipnodes netgroup networks rpc services protocols netid 531.5Slukem 541.16Schristos__makedbmesc: .USEBEFORE 551.16Schristos if [ -f ${.ALLSRC} ]; then \ 561.16Schristos ${SED} -e "s/#.*$$//" ${.ALLSRC} | \ 571.16Schristos ${AWK} '{ \ 581.16Schristos if (NF == 0) \ 591.16Schristos printf("\n"); \ 601.16Schristos else { \ 611.16Schristos for (i = 1; i <= NF; i++) { \ 621.16Schristos if (i == NF) { \ 631.16Schristos if (substr($$i, length($$i), 1) == "\\") { \ 641.16Schristos printf("%s", substr($$i, 1, \ 651.16Schristos length($$i) - 1)); \ 661.16Schristos } else \ 671.16Schristos printf("%s\n", $$i); \ 681.16Schristos } else \ 691.16Schristos printf("%s ", $$i); \ 701.16Schristos } \ 711.16Schristos } \ 721.16Schristos }' | \ 731.16Schristos ${SED} -e "/^[ \t]*$$/d" | \ 741.16Schristos ${SORT} | ${MAKEDBM} - ${.ALLSRC:T}; \ 751.16Schristos fi 761.5Slukem 771.5Slukempasswd.time: ${DIR}/master.passwd 781.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 791.5Slukem umask 077 ; \ 801.5Slukem if [ "${INSECURE}" != "yes" ]; then \ 811.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 | \ 821.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 831.5Slukem { print $$1, $$1":*:"$$3":"$$4":"$$5":"$$6":"$$7 }' -|\ 841.9Sabs ${SORT} | ${MAKEDBM} - passwd.byname; \ 851.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 |\ 861.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 871.5Slukem { print $$3, $$1":*:"$$3":"$$4":"$$5":"$$6":"$$7 }' -|\ 881.9Sabs ${SORT} | ${MAKEDBM} - passwd.byuid; \ 891.5Slukem else \ 901.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 | \ 911.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 921.9Sabs { print $$1, $$0 }' - | ${SORT} | \ 931.9Sabs ${MAKEDBM} - passwd.byname; \ 941.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 |\ 951.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 961.9Sabs { print $$3, $$0 }' - | ${SORT} | \ 971.9Sabs ${MAKEDBM} - passwd.byuid; \ 981.5Slukem fi; \ 991.5Slukem ${CAT} ${.ALLSRC} | \ 1001.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1011.9Sabs { print $$1, $$0 }' - | ${SORT} | \ 1021.9Sabs ${MAKEDBM_S} - master.passwd.byname; \ 1031.5Slukem ${CAT} ${.ALLSRC} | \ 1041.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1051.9Sabs { print $$3, $$0 }' - | ${SORT} | \ 1061.9Sabs ${MAKEDBM_S} - master.passwd.byuid; \ 1071.5Slukem ${TOUCH} ${.TARGET}; \ 1081.5Slukem ${ECHO} "updated passwd"; \ 1091.5Slukem if [ ! ${NOPUSH} ]; then \ 1101.5Slukem ${YPPUSH} -d ${DOMAIN} passwd.byname; \ 1111.5Slukem ${YPPUSH} -d ${DOMAIN} passwd.byuid; \ 1121.5Slukem ${YPPUSH} -d ${DOMAIN} master.passwd.byname; \ 1131.5Slukem ${YPPUSH} -d ${DOMAIN} master.passwd.byuid; \ 1141.5Slukem ${ECHO} "pushed passwd"; \ 1151.5Slukem else \ 1161.5Slukem : ; \ 1171.5Slukem fi \ 1181.5Slukem else \ 1191.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1201.5Slukem fi 1211.5Slukem 1221.11Schristos# XXX: This does not do modify/expire time correctly. 1231.11Schristosshadow.time: ${DIR}/master.passwd 1241.11Schristos -@if [ -f ${.ALLSRC} ]; then \ 1251.11Schristos umask 077 ; \ 1261.11Schristos ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-2 | \ 1271.11Schristos ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1281.11Schristos { print $$1, $$0":10779:0:99999:7:::" }' - | \ 1291.12Schristos ${SORT} | ${MAKEDBM_S} - shadow.byname; \ 1301.11Schristos ${TOUCH} ${.TARGET}; \ 1311.11Schristos ${ECHO} "updated shadow"; \ 1321.11Schristos if [ ! ${NOPUSH} ]; then \ 1331.11Schristos ${YPPUSH} -d ${DOMAIN} shadow.byname; \ 1341.11Schristos ${ECHO} "pushed shadow"; \ 1351.11Schristos else \ 1361.11Schristos : ; \ 1371.11Schristos fi \ 1381.11Schristos else \ 1391.11Schristos ${ECHO} "couldn't find ${.ALLSRC}"; \ 1401.11Schristos fi 1411.5Slukem 1421.13Sitojunaliases.time: ${DIR}/mail/aliases 1431.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1441.5Slukem ${CP} -p ${.ALLSRC} ${DOMAIN}-aliases; \ 1451.5Slukem ${SENDMAIL} -bi -oA${PWD}/${DOMAIN}-aliases; \ 1461.9Sabs ${MAKEDBM} -u ${DOMAIN}-aliases | ${SORT} | \ 1471.9Sabs ${MAKEDBM} - mail.aliases; \ 1481.5Slukem ${MKALIAS} mail.aliases mail.byaddr; \ 1491.5Slukem ${TOUCH} ${.TARGET}; \ 1501.5Slukem ${RM} ${DOMAIN}-aliases.db ${DOMAIN}-aliases; \ 1511.5Slukem ${ECHO} "updated aliases"; \ 1521.5Slukem if [ ! ${NOPUSH} ]; then \ 1531.5Slukem ${YPPUSH} -d ${DOMAIN} mail.aliases; \ 1541.5Slukem ${YPPUSH} -d ${DOMAIN} mail.byaddr; \ 1551.5Slukem ${ECHO} "pushed aliases"; \ 1561.5Slukem else \ 1571.5Slukem : ; \ 1581.5Slukem fi \ 1591.5Slukem else \ 1601.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1611.5Slukem fi 1621.5Slukem 1631.1Sthorpej 1641.17Shubertf.for MAP in ${AMDMAPS} 1651.17Shubertf${MAP}.time: ${AMDDIR}/${MAP} __makedbmesc 1661.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1671.5Slukem ${TOUCH} ${.TARGET}; \ 1681.17Shubertf ${ECHO} "updated ${MAP}"; \ 1691.5Slukem if [ ! ${NOPUSH} ]; then \ 1701.17Shubertf ${YPPUSH} -d ${DOMAIN} ${MAP}; \ 1711.17Shubertf ${ECHO} "pushed ${MAP}"; \ 1721.1Sthorpej else \ 1731.1Sthorpej : ; \ 1741.1Sthorpej fi \ 1751.1Sthorpej else \ 1761.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1771.1Sthorpej fi 1781.17Shubertf.endfor # AMDMAPS 1791.1Sthorpej 1801.1Sthorpej 1811.5Slukemethers.time: ${DIR}/ethers 1821.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1831.5Slukem ${STDETHERS} ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 1841.5Slukem ${AWK} 'BEGIN { FS="\t"; OFS="\t"; } { print $$1, $$0 }' | \ 1851.9Sabs ${SORT} | ${MAKEDBM} - ethers.byaddr; \ 1861.5Slukem ${STDETHERS} ${.ALLSRC} | \ 1871.5Slukem ${AWK} 'BEGIN { FS="\t"; OFS="\t"; } { print $$2, $$0 }' | \ 1881.9Sabs ${SORT} | ${MAKEDBM} - ethers.byname; \ 1891.5Slukem ${TOUCH} ${.TARGET}; \ 1901.5Slukem ${ECHO} "updated ethers"; \ 1911.5Slukem if [ ! ${NOPUSH} ]; then \ 1921.5Slukem ${YPPUSH} -d ${DOMAIN} ethers.byaddr; \ 1931.5Slukem ${YPPUSH} -d ${DOMAIN} ethers.byname; \ 1941.5Slukem ${ECHO} "pushed ethers"; \ 1951.1Sthorpej else \ 1961.1Sthorpej : ; \ 1971.1Sthorpej fi \ 1981.1Sthorpej else \ 1991.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2001.1Sthorpej fi 2011.1Sthorpej 2021.5Slukem 2031.5Slukemgroup.time: ${DIR}/group 2041.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2051.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 2061.5Slukem { print $$1, $$0 }' ${.ALLSRC} | \ 2071.9Sabs ${SORT} | ${MAKEDBM} - group.byname; \ 2081.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 2091.5Slukem { print $$3, $$0 }' ${.ALLSRC} | \ 2101.9Sabs ${SORT} | ${MAKEDBM} - group.bygid; \ 2111.5Slukem ${TOUCH} ${.TARGET}; \ 2121.5Slukem ${ECHO} "updated group"; \ 2131.5Slukem if [ ! ${NOPUSH} ]; then \ 2141.5Slukem ${YPPUSH} -d ${DOMAIN} group.byname; \ 2151.5Slukem ${YPPUSH} -d ${DOMAIN} group.bygid; \ 2161.5Slukem ${ECHO} "pushed group"; \ 2171.1Sthorpej else \ 2181.1Sthorpej : ; \ 2191.1Sthorpej fi \ 2201.1Sthorpej else \ 2211.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2221.1Sthorpej fi 2231.1Sthorpej 2241.5Slukem 2251.10Sitojun# Solaris 8 does the following: 2261.10Sitojun# - /etc/hosts and hosts.{byname,byaddr} are IPv4 only. 2271.10Sitojun# - /etc/inet/ipnodes and ipnodes.{byname,byaddr} are used for protocol 2281.10Sitojun# independent name-to-address mapping. 2291.10Sitojun# 2301.10Sitojun# For local name resolution, we made /etc/hosts protocol independent. 2311.10Sitojun# For NIS name resolution, we obey Solaris 8 practice. 2321.10Sitojun# - We keep hosts.{byname,byaddr} IPv4 only, to be friendly with Solaris 8 2331.10Sitojun# clients. 2341.10Sitojun# - ipnodes.{byname,byaddr} is used for protocol independent mapping. 2351.10Sitojun# We generate all the mappings from /etc/hosts, for compatibility with NetBSD 2361.10Sitojun# local name resolution. 2371.10Sitojun# 2381.5Slukemhosts.time: ${DIR}/hosts 2391.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2401.5Slukem ${STDHOSTS} ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 2411.5Slukem ${AWK} '{for (i = 2; i <= NF; i++) print $$i, $$0 }' | \ 2421.9Sabs ${SORT} | ${MAKEDBM} - hosts.byname; \ 2431.5Slukem ${STDHOSTS} ${.ALLSRC} | \ 2441.5Slukem ${AWK} 'BEGIN { OFS="\t"; } { print $$1, $$0 }' | \ 2451.9Sabs ${SORT} | ${MAKEDBM} - hosts.byaddr; \ 2461.5Slukem ${TOUCH} ${.TARGET}; \ 2471.5Slukem ${ECHO} "updated hosts"; \ 2481.5Slukem if [ ! ${NOPUSH} ]; then \ 2491.5Slukem ${YPPUSH} -d ${DOMAIN} hosts.byname; \ 2501.5Slukem ${YPPUSH} -d ${DOMAIN} hosts.byaddr; \ 2511.5Slukem ${ECHO} "pushed hosts"; \ 2521.1Sthorpej else \ 2531.1Sthorpej : ; \ 2541.1Sthorpej fi \ 2551.1Sthorpej else \ 2561.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2571.1Sthorpej fi 2581.1Sthorpej 2591.5Slukem 2601.10Sitojunipnodes.time: ${DIR}/hosts 2611.10Sitojun -@if [ -f ${.ALLSRC} ]; then \ 2621.10Sitojun ${STDHOSTS} -n ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 2631.10Sitojun ${AWK} '{for (i = 2; i <= NF; i++) print $$i, $$0 }' | \ 2641.10Sitojun ${SORT} | ${MAKEDBM} - ipnodes.byname; \ 2651.10Sitojun ${STDHOSTS} -n ${.ALLSRC} | \ 2661.10Sitojun ${AWK} 'BEGIN { OFS="\t"; } { print $$1, $$0 }' | \ 2671.10Sitojun ${SORT} | ${MAKEDBM} - ipnodes.byaddr; \ 2681.10Sitojun ${TOUCH} ${.TARGET}; \ 2691.10Sitojun ${ECHO} "updated ipnodes"; \ 2701.10Sitojun if [ ! ${NOPUSH} ]; then \ 2711.10Sitojun ${YPPUSH} -d ${DOMAIN} ipnodes.byname; \ 2721.10Sitojun ${YPPUSH} -d ${DOMAIN} ipnodes.byaddr; \ 2731.10Sitojun ${ECHO} "pushed ipnodes"; \ 2741.10Sitojun else \ 2751.10Sitojun : ; \ 2761.10Sitojun fi \ 2771.10Sitojun else \ 2781.10Sitojun ${ECHO} "couldn't find ${.ALLSRC}"; \ 2791.10Sitojun fi 2801.10Sitojun 2811.10Sitojun 2821.16Schristosnetgroup.time: ${DIR}/netgroup __makedbmesc 2831.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2841.5Slukem ${CAT} ${.ALLSRC} | ${REVNETGROUP} -u -f - | \ 2851.9Sabs ${SORT} | ${MAKEDBM} - netgroup.byuser; \ 2861.5Slukem ${CAT} ${.ALLSRC} | ${REVNETGROUP} -h -f - | \ 2871.9Sabs ${SORT} | ${MAKEDBM} - netgroup.byhost; \ 2881.5Slukem ${TOUCH} ${.TARGET}; \ 2891.5Slukem ${ECHO} "updated netgroup"; \ 2901.5Slukem if [ ! ${NOPUSH} ]; then \ 2911.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup; \ 2921.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup.byuser; \ 2931.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup.byhost; \ 2941.5Slukem ${ECHO} "pushed netgroup"; \ 2951.1Sthorpej else \ 2961.1Sthorpej : ; \ 2971.1Sthorpej fi \ 2981.1Sthorpej else \ 2991.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3001.1Sthorpej fi 3011.1Sthorpej 3021.5Slukem 3031.5Slukemnetworks.time: ${DIR}/networks 3041.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3051.5Slukem ${SED} -e "/^#/d" -e s/#.*$$// ${.ALLSRC} | \ 3061.5Slukem ${AWK} '{print $$1, $$0; \ 3071.5Slukem for (i = 3;i <= NF;i++) print $$i,$$0}' | \ 3081.9Sabs ${SORT} | ${MAKEDBM} - networks.byname; \ 3091.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3101.5Slukem ${.ALLSRC} | \ 3111.9Sabs ${SORT} | ${MAKEDBM} - networks.byaddr; \ 3121.5Slukem ${TOUCH} ${.TARGET}; \ 3131.5Slukem ${ECHO} "updated networks"; \ 3141.5Slukem if [ ! ${NOPUSH} ]; then \ 3151.5Slukem ${YPPUSH} -d ${DOMAIN} networks.byname; \ 3161.5Slukem ${YPPUSH} -d ${DOMAIN} networks.byaddr; \ 3171.5Slukem ${ECHO} "pushed networks"; \ 3181.1Sthorpej else \ 3191.1Sthorpej : ; \ 3201.1Sthorpej fi \ 3211.1Sthorpej else \ 3221.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3231.1Sthorpej fi 3241.1Sthorpej 3251.1Sthorpej 3261.5Slukemprotocols.time: ${DIR}/protocols 3271.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3281.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3291.5Slukem ${.ALLSRC} | \ 3301.9Sabs ${SORT} | ${MAKEDBM} - protocols.bynumber; \ 3311.5Slukem ${SED} -e "/^#/d" -e s/#.*$$// ${.ALLSRC} | \ 3321.5Slukem ${AWK} '{print $$1, $$0; \ 3331.5Slukem for (i = 3;i <= NF;i++) print $$i,$$0}' | \ 3341.9Sabs ${SORT} | ${MAKEDBM} - protocols.byname; \ 3351.5Slukem ${TOUCH} ${.TARGET}; \ 3361.5Slukem ${ECHO} "updated protocols"; \ 3371.5Slukem if [ ! ${NOPUSH} ]; then \ 3381.5Slukem ${YPPUSH} -d ${DOMAIN} protocols.bynumber; \ 3391.5Slukem ${YPPUSH} -d ${DOMAIN} protocols.byname; \ 3401.5Slukem ${ECHO} "pushed protocols"; \ 3411.1Sthorpej else \ 3421.1Sthorpej : ; \ 3431.1Sthorpej fi \ 3441.1Sthorpej else \ 3451.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3461.1Sthorpej fi 3471.1Sthorpej 3481.1Sthorpej 3491.5Slukemrpc.time: ${DIR}/rpc 3501.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3511.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3521.5Slukem ${.ALLSRC} | \ 3531.9Sabs ${SORT} | ${MAKEDBM} - rpc.bynumber; \ 3541.5Slukem ${TOUCH} ${.TARGET}; \ 3551.5Slukem ${ECHO} "updated rpc"; \ 3561.5Slukem if [ ! ${NOPUSH} ]; then \ 3571.5Slukem ${YPPUSH} -d ${DOMAIN} rpc.bynumber; \ 3581.5Slukem ${ECHO} "pushed rpc"; \ 3591.1Sthorpej else \ 3601.1Sthorpej : ; \ 3611.1Sthorpej fi \ 3621.1Sthorpej else \ 3631.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3641.1Sthorpej fi 3651.1Sthorpej 3661.1Sthorpej 3671.5Slukemservices.time: ${DIR}/services 3681.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3691.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3701.5Slukem ${.ALLSRC} | \ 3711.9Sabs ${SORT} | ${MAKEDBM} - services.byname; \ 3721.5Slukem ${TOUCH} ${.TARGET}; \ 3731.5Slukem ${ECHO} "updated services"; \ 3741.5Slukem if [ ! ${NOPUSH} ]; then \ 3751.5Slukem ${YPPUSH} -d ${DOMAIN} services.byname; \ 3761.5Slukem ${ECHO} "pushed services"; \ 3771.5Slukem else \ 3781.5Slukem : ; \ 3791.5Slukem fi \ 3801.5Slukem else \ 3811.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3821.5Slukem fi 3831.5Slukem 3841.5Slukem 3851.5Slukemnetid.time: ${DIR}/passwd ${DIR}/group ${DIR}/hosts ${DIR}/netid 3861.5Slukem -@${MKNETID} -q -d ${DOMAIN} -p ${DIR}/passwd -g ${DIR}/group -h \ 3871.5Slukem ${DIR}/hosts -m ${DIR}/netid | \ 3881.9Sabs ${SORT} | ${MAKEDBM} - netid.byname; \ 3891.5Slukem ${TOUCH} ${.TARGET}; \ 3901.5Slukem ${ECHO} "updated netid"; \ 3911.5Slukem if [ ! ${NOPUSH} ]; then \ 3921.5Slukem ${YPPUSH} -d ${DOMAIN} netid.byname; \ 3931.5Slukem ${ECHO} "pushed netid"; \ 3941.1Sthorpej else \ 3951.1Sthorpej : ; \ 3961.1Sthorpej fi 3971.1Sthorpej 3981.5Slukem 3991.6Slukemypservers.time: ${.CURDIR}/ypservers 4001.6Slukem -@${MAKEDBM} ypservers ypservers; \ 4011.6Slukem ${TOUCH} ${.TARGET}; \ 4021.5Slukem ${ECHO} "updated ypservers"; \ 4031.5Slukem if [ ! ${NOPUSH} ]; then \ 4041.5Slukem ${YPPUSH} -d ${DOMAIN} ypservers; \ 4051.5Slukem ${ECHO} "pushed ypservers"; \ 4061.2Sthorpej else \ 4071.2Sthorpej : ; \ 4081.2Sthorpej fi 4091.1Sthorpej 4101.5Slukem 4111.1Sthorpejpasswd: passwd.time 4121.1Sthorpejgroup: group.time 4131.1Sthorpejhosts: hosts.time 4141.10Sitojunipnodes: ipnodes.time 4151.5Slukemaliases: aliases.time 4161.17Shubertf.for MAP in ${AMDMAPS} 4171.17Shubertf${MAP}: ${MAP}.time 4181.17Shubertf.endfor # AMDMAPS 4191.1Sthorpejethers: ethers.time 4201.5Slukemnetgroup: netgroup.time 4211.1Sthorpejnetworks: networks.time 4221.1Sthorpejrpc: rpc.time 4231.1Sthorpejservices: services.time 4241.11Schristosshadow: shadow.time 4251.1Sthorpejprotocols: protocols.time 4261.1Sthorpejnetid: netid.time 4271.6Slukemypservers: ypservers.time 4281.5Slukem 4291.5Slukem${DIR}/passwd: 4301.5Slukem${DIR}/group: 4311.5Slukem${DIR}/hosts: 4321.13Sitojun${DIR}/mail/aliases: 4331.17Shubertf.for MAP in ${AMDMAPS} 4341.17Shubertf${AMDDIR}/${MAP}: 4351.17Shubertf.endfor # AMDMAPS 4361.5Slukem${DIR}/ethers: 4371.5Slukem${DIR}/master.passwd: 4381.5Slukem${DIR}/netgroup: 4391.5Slukem${DIR}/networks: 4401.5Slukem${DIR}/rpc: 4411.5Slukem${DIR}/services: 4421.5Slukem${DIR}/protocols: 4431.5Slukem${DIR}/netid: 444