Makefile.yp revision 1.21
11.21Selad# $NetBSD: Makefile.yp,v 1.21 2006/10/07 16:54:38 elad 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.19Schristos# Only include UID's >= ${MINUID} in the maps. Setting this to ~1000 211.19Schristos# and using uid's > 1000 for users allows heterogeneous system support 221.19Schristos# where low numbered uids and gids may have different meanings. 231.19SchristosMINUID?= 0 241.19SchristosMINGID?= 0 251.19Schristos 261.11Schristos# In addition, by adding shadow to the list of rules we support 271.11Schristos# linux and solaris type shadow maps. 281.5Slukem 291.5SlukemYPDBDIR= /var/yp 301.5SlukemDIR= /etc 311.5SlukemAMDDIR= /etc/amd 321.17ShubertfAMDMAPS= amd.home 331.17ShubertfDOMAIN= ${.CURDIR:T} 341.5Slukem 351.5SlukemAWK= /usr/bin/awk 361.5SlukemCAT= /bin/cat 371.5SlukemCP= /bin/cp 381.5SlukemCUT= /usr/bin/cut 391.5SlukemECHO= /bin/echo 401.18SchristosEGREP= /usr/bin/egrep 411.5SlukemMAKEDBM= /usr/sbin/makedbm 421.5SlukemMAKEDBM_S= ${MAKEDBM} -s 431.5SlukemMKALIAS= /usr/sbin/mkalias 441.5SlukemMKNETID= /usr/sbin/mknetid 451.5SlukemREVNETGROUP= /usr/sbin/revnetgroup 461.5SlukemRM= /bin/rm 471.5SlukemSED= /usr/bin/sed 481.5SlukemSENDMAIL= /usr/sbin/sendmail 491.9SabsSORT= /usr/bin/sort 501.5SlukemSTDETHERS= /usr/sbin/stdethers 511.20SgrantSTDHOSTS= /usr/sbin/stdhosts -n 521.5SlukemTOUCH= /usr/bin/touch 531.5SlukemYPPUSH= /usr/sbin/yppush 541.5Slukem 551.1Sthorpej 561.2Sthorpej# We have a rule for ypservers, but we don't build it by default, since 571.2Sthorpej# it seldom changes (only when slaves are added/deleted). 581.2Sthorpej 591.17Shubertfall: passwd aliases ${AMDMAPS} ethers group hosts ipnodes netgroup networks rpc services protocols netid 601.5Slukem 611.16Schristos__makedbmesc: .USEBEFORE 621.16Schristos if [ -f ${.ALLSRC} ]; then \ 631.16Schristos ${SED} -e "s/#.*$$//" ${.ALLSRC} | \ 641.16Schristos ${AWK} '{ \ 651.16Schristos if (NF == 0) \ 661.16Schristos printf("\n"); \ 671.16Schristos else { \ 681.16Schristos for (i = 1; i <= NF; i++) { \ 691.16Schristos if (i == NF) { \ 701.16Schristos if (substr($$i, length($$i), 1) == "\\") { \ 711.16Schristos printf("%s", substr($$i, 1, \ 721.16Schristos length($$i) - 1)); \ 731.16Schristos } else \ 741.16Schristos printf("%s\n", $$i); \ 751.16Schristos } else \ 761.16Schristos printf("%s ", $$i); \ 771.16Schristos } \ 781.16Schristos } \ 791.16Schristos }' | \ 801.16Schristos ${SED} -e "/^[ \t]*$$/d" | \ 811.16Schristos ${SORT} | ${MAKEDBM} - ${.ALLSRC:T}; \ 821.16Schristos fi 831.5Slukem 841.5Slukempasswd.time: ${DIR}/master.passwd 851.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 861.5Slukem umask 077 ; \ 871.5Slukem if [ "${INSECURE}" != "yes" ]; then \ 881.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 | \ 891.19Schristos ${AWK} -v minuid=${MINUID} \ 901.19Schristos 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 911.19Schristos { if (minuid <= $$3) \ 921.19Schristos print $$1, $$1":*:"$$3":"$$4":"$$5":"$$6":"$$7 }' -|\ 931.9Sabs ${SORT} | ${MAKEDBM} - passwd.byname; \ 941.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 |\ 951.19Schristos ${AWK} -v minuid=${MINUID} \ 961.19Schristos 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 971.19Schristos { if (minuid <= $$3) \ 981.19Schristos print $$3, $$1":*:"$$3":"$$4":"$$5":"$$6":"$$7 }' -|\ 991.9Sabs ${SORT} | ${MAKEDBM} - passwd.byuid; \ 1001.5Slukem else \ 1011.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 | \ 1021.19Schristos ${AWK} -v minuid=${MINUID} \ 1031.19Schristos 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1041.19Schristos { if (minuid <= $$3) \ 1051.19Schristos print $$1, $$0 }' - | ${SORT} | \ 1061.9Sabs ${MAKEDBM} - passwd.byname; \ 1071.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 |\ 1081.19Schristos ${AWK} -v minuid=${MINUID} \ 1091.19Schristos 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1101.19Schristos { if (minuid <= $$3) \ 1111.19Schristos print $$3, $$0 }' - | ${SORT} | \ 1121.9Sabs ${MAKEDBM} - passwd.byuid; \ 1131.5Slukem fi; \ 1141.5Slukem ${CAT} ${.ALLSRC} | \ 1151.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1161.9Sabs { print $$1, $$0 }' - | ${SORT} | \ 1171.9Sabs ${MAKEDBM_S} - master.passwd.byname; \ 1181.5Slukem ${CAT} ${.ALLSRC} | \ 1191.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1201.9Sabs { print $$3, $$0 }' - | ${SORT} | \ 1211.9Sabs ${MAKEDBM_S} - master.passwd.byuid; \ 1221.5Slukem ${TOUCH} ${.TARGET}; \ 1231.5Slukem ${ECHO} "updated passwd"; \ 1241.5Slukem if [ ! ${NOPUSH} ]; then \ 1251.5Slukem ${YPPUSH} -d ${DOMAIN} passwd.byname; \ 1261.5Slukem ${YPPUSH} -d ${DOMAIN} passwd.byuid; \ 1271.5Slukem ${YPPUSH} -d ${DOMAIN} master.passwd.byname; \ 1281.5Slukem ${YPPUSH} -d ${DOMAIN} master.passwd.byuid; \ 1291.5Slukem ${ECHO} "pushed passwd"; \ 1301.5Slukem else \ 1311.5Slukem : ; \ 1321.5Slukem fi \ 1331.5Slukem else \ 1341.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1351.5Slukem fi 1361.5Slukem 1371.11Schristos# XXX: This does not do modify/expire time correctly. 1381.11Schristosshadow.time: ${DIR}/master.passwd 1391.11Schristos -@if [ -f ${.ALLSRC} ]; then \ 1401.11Schristos umask 077 ; \ 1411.21Selad ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-3 | \ 1421.21Selad ${AWK} -v minuid=${MINUID} \ 1431.21Selad 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1441.21Selad { if (minuid <= $$3) \ 1451.21Selad print $$1, $$1":"$$2":10779:0:99999:7:::" }' - | \ 1461.12Schristos ${SORT} | ${MAKEDBM_S} - shadow.byname; \ 1471.11Schristos ${TOUCH} ${.TARGET}; \ 1481.11Schristos ${ECHO} "updated shadow"; \ 1491.11Schristos if [ ! ${NOPUSH} ]; then \ 1501.11Schristos ${YPPUSH} -d ${DOMAIN} shadow.byname; \ 1511.11Schristos ${ECHO} "pushed shadow"; \ 1521.11Schristos else \ 1531.11Schristos : ; \ 1541.11Schristos fi \ 1551.11Schristos else \ 1561.11Schristos ${ECHO} "couldn't find ${.ALLSRC}"; \ 1571.11Schristos fi 1581.5Slukem 1591.13Sitojunaliases.time: ${DIR}/mail/aliases 1601.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1611.5Slukem ${CP} -p ${.ALLSRC} ${DOMAIN}-aliases; \ 1621.5Slukem ${SENDMAIL} -bi -oA${PWD}/${DOMAIN}-aliases; \ 1631.9Sabs ${MAKEDBM} -u ${DOMAIN}-aliases | ${SORT} | \ 1641.18Schristos ${EGREP} -v '(YP_LAST_MODIFIED|YP_MASTER_NAME)' | \ 1651.9Sabs ${MAKEDBM} - mail.aliases; \ 1661.5Slukem ${MKALIAS} mail.aliases mail.byaddr; \ 1671.5Slukem ${TOUCH} ${.TARGET}; \ 1681.5Slukem ${RM} ${DOMAIN}-aliases.db ${DOMAIN}-aliases; \ 1691.5Slukem ${ECHO} "updated aliases"; \ 1701.5Slukem if [ ! ${NOPUSH} ]; then \ 1711.5Slukem ${YPPUSH} -d ${DOMAIN} mail.aliases; \ 1721.5Slukem ${YPPUSH} -d ${DOMAIN} mail.byaddr; \ 1731.5Slukem ${ECHO} "pushed aliases"; \ 1741.5Slukem else \ 1751.5Slukem : ; \ 1761.5Slukem fi \ 1771.5Slukem else \ 1781.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1791.5Slukem fi 1801.5Slukem 1811.1Sthorpej 1821.17Shubertf.for MAP in ${AMDMAPS} 1831.17Shubertf${MAP}.time: ${AMDDIR}/${MAP} __makedbmesc 1841.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1851.5Slukem ${TOUCH} ${.TARGET}; \ 1861.17Shubertf ${ECHO} "updated ${MAP}"; \ 1871.5Slukem if [ ! ${NOPUSH} ]; then \ 1881.17Shubertf ${YPPUSH} -d ${DOMAIN} ${MAP}; \ 1891.17Shubertf ${ECHO} "pushed ${MAP}"; \ 1901.1Sthorpej else \ 1911.1Sthorpej : ; \ 1921.1Sthorpej fi \ 1931.1Sthorpej else \ 1941.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1951.1Sthorpej fi 1961.17Shubertf.endfor # AMDMAPS 1971.1Sthorpej 1981.1Sthorpej 1991.5Slukemethers.time: ${DIR}/ethers 2001.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2011.5Slukem ${STDETHERS} ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 2021.5Slukem ${AWK} 'BEGIN { FS="\t"; OFS="\t"; } { print $$1, $$0 }' | \ 2031.9Sabs ${SORT} | ${MAKEDBM} - ethers.byaddr; \ 2041.5Slukem ${STDETHERS} ${.ALLSRC} | \ 2051.5Slukem ${AWK} 'BEGIN { FS="\t"; OFS="\t"; } { print $$2, $$0 }' | \ 2061.9Sabs ${SORT} | ${MAKEDBM} - ethers.byname; \ 2071.5Slukem ${TOUCH} ${.TARGET}; \ 2081.5Slukem ${ECHO} "updated ethers"; \ 2091.5Slukem if [ ! ${NOPUSH} ]; then \ 2101.5Slukem ${YPPUSH} -d ${DOMAIN} ethers.byaddr; \ 2111.5Slukem ${YPPUSH} -d ${DOMAIN} ethers.byname; \ 2121.5Slukem ${ECHO} "pushed ethers"; \ 2131.1Sthorpej else \ 2141.1Sthorpej : ; \ 2151.1Sthorpej fi \ 2161.1Sthorpej else \ 2171.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2181.1Sthorpej fi 2191.1Sthorpej 2201.5Slukem 2211.5Slukemgroup.time: ${DIR}/group 2221.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2231.19Schristos ${AWK} -v mingid=${MINGID} \ 2241.19Schristos 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 2251.19Schristos { if (mingid <= $$3) print $$1, $$0 }' ${.ALLSRC} | \ 2261.9Sabs ${SORT} | ${MAKEDBM} - group.byname; \ 2271.19Schristos ${AWK} -v mingid=${MINGID} \ 2281.19Schristos 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 2291.19Schristos { if (mingid <= $$3) print $$3, $$0 }' ${.ALLSRC} | \ 2301.9Sabs ${SORT} | ${MAKEDBM} - group.bygid; \ 2311.5Slukem ${TOUCH} ${.TARGET}; \ 2321.5Slukem ${ECHO} "updated group"; \ 2331.5Slukem if [ ! ${NOPUSH} ]; then \ 2341.5Slukem ${YPPUSH} -d ${DOMAIN} group.byname; \ 2351.5Slukem ${YPPUSH} -d ${DOMAIN} group.bygid; \ 2361.5Slukem ${ECHO} "pushed group"; \ 2371.1Sthorpej else \ 2381.1Sthorpej : ; \ 2391.1Sthorpej fi \ 2401.1Sthorpej else \ 2411.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2421.1Sthorpej fi 2431.1Sthorpej 2441.5Slukem 2451.10Sitojun# Solaris 8 does the following: 2461.10Sitojun# - /etc/hosts and hosts.{byname,byaddr} are IPv4 only. 2471.10Sitojun# - /etc/inet/ipnodes and ipnodes.{byname,byaddr} are used for protocol 2481.10Sitojun# independent name-to-address mapping. 2491.10Sitojun# 2501.10Sitojun# For local name resolution, we made /etc/hosts protocol independent. 2511.10Sitojun# For NIS name resolution, we obey Solaris 8 practice. 2521.10Sitojun# - We keep hosts.{byname,byaddr} IPv4 only, to be friendly with Solaris 8 2531.10Sitojun# clients. 2541.10Sitojun# - ipnodes.{byname,byaddr} is used for protocol independent mapping. 2551.10Sitojun# We generate all the mappings from /etc/hosts, for compatibility with NetBSD 2561.10Sitojun# local name resolution. 2571.10Sitojun# 2581.5Slukemhosts.time: ${DIR}/hosts 2591.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2601.5Slukem ${STDHOSTS} ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 2611.5Slukem ${AWK} '{for (i = 2; i <= NF; i++) print $$i, $$0 }' | \ 2621.9Sabs ${SORT} | ${MAKEDBM} - hosts.byname; \ 2631.5Slukem ${STDHOSTS} ${.ALLSRC} | \ 2641.5Slukem ${AWK} 'BEGIN { OFS="\t"; } { print $$1, $$0 }' | \ 2651.9Sabs ${SORT} | ${MAKEDBM} - hosts.byaddr; \ 2661.5Slukem ${TOUCH} ${.TARGET}; \ 2671.5Slukem ${ECHO} "updated hosts"; \ 2681.5Slukem if [ ! ${NOPUSH} ]; then \ 2691.5Slukem ${YPPUSH} -d ${DOMAIN} hosts.byname; \ 2701.5Slukem ${YPPUSH} -d ${DOMAIN} hosts.byaddr; \ 2711.5Slukem ${ECHO} "pushed hosts"; \ 2721.1Sthorpej else \ 2731.1Sthorpej : ; \ 2741.1Sthorpej fi \ 2751.1Sthorpej else \ 2761.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2771.1Sthorpej fi 2781.1Sthorpej 2791.5Slukem 2801.10Sitojunipnodes.time: ${DIR}/hosts 2811.10Sitojun -@if [ -f ${.ALLSRC} ]; then \ 2821.10Sitojun ${STDHOSTS} -n ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 2831.10Sitojun ${AWK} '{for (i = 2; i <= NF; i++) print $$i, $$0 }' | \ 2841.10Sitojun ${SORT} | ${MAKEDBM} - ipnodes.byname; \ 2851.10Sitojun ${STDHOSTS} -n ${.ALLSRC} | \ 2861.10Sitojun ${AWK} 'BEGIN { OFS="\t"; } { print $$1, $$0 }' | \ 2871.10Sitojun ${SORT} | ${MAKEDBM} - ipnodes.byaddr; \ 2881.10Sitojun ${TOUCH} ${.TARGET}; \ 2891.10Sitojun ${ECHO} "updated ipnodes"; \ 2901.10Sitojun if [ ! ${NOPUSH} ]; then \ 2911.10Sitojun ${YPPUSH} -d ${DOMAIN} ipnodes.byname; \ 2921.10Sitojun ${YPPUSH} -d ${DOMAIN} ipnodes.byaddr; \ 2931.10Sitojun ${ECHO} "pushed ipnodes"; \ 2941.10Sitojun else \ 2951.10Sitojun : ; \ 2961.10Sitojun fi \ 2971.10Sitojun else \ 2981.10Sitojun ${ECHO} "couldn't find ${.ALLSRC}"; \ 2991.10Sitojun fi 3001.10Sitojun 3011.10Sitojun 3021.16Schristosnetgroup.time: ${DIR}/netgroup __makedbmesc 3031.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3041.5Slukem ${CAT} ${.ALLSRC} | ${REVNETGROUP} -u -f - | \ 3051.9Sabs ${SORT} | ${MAKEDBM} - netgroup.byuser; \ 3061.5Slukem ${CAT} ${.ALLSRC} | ${REVNETGROUP} -h -f - | \ 3071.9Sabs ${SORT} | ${MAKEDBM} - netgroup.byhost; \ 3081.5Slukem ${TOUCH} ${.TARGET}; \ 3091.5Slukem ${ECHO} "updated netgroup"; \ 3101.5Slukem if [ ! ${NOPUSH} ]; then \ 3111.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup; \ 3121.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup.byuser; \ 3131.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup.byhost; \ 3141.5Slukem ${ECHO} "pushed netgroup"; \ 3151.1Sthorpej else \ 3161.1Sthorpej : ; \ 3171.1Sthorpej fi \ 3181.1Sthorpej else \ 3191.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3201.1Sthorpej fi 3211.1Sthorpej 3221.5Slukem 3231.5Slukemnetworks.time: ${DIR}/networks 3241.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3251.5Slukem ${SED} -e "/^#/d" -e s/#.*$$// ${.ALLSRC} | \ 3261.5Slukem ${AWK} '{print $$1, $$0; \ 3271.5Slukem for (i = 3;i <= NF;i++) print $$i,$$0}' | \ 3281.9Sabs ${SORT} | ${MAKEDBM} - networks.byname; \ 3291.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3301.5Slukem ${.ALLSRC} | \ 3311.9Sabs ${SORT} | ${MAKEDBM} - networks.byaddr; \ 3321.5Slukem ${TOUCH} ${.TARGET}; \ 3331.5Slukem ${ECHO} "updated networks"; \ 3341.5Slukem if [ ! ${NOPUSH} ]; then \ 3351.5Slukem ${YPPUSH} -d ${DOMAIN} networks.byname; \ 3361.5Slukem ${YPPUSH} -d ${DOMAIN} networks.byaddr; \ 3371.5Slukem ${ECHO} "pushed networks"; \ 3381.1Sthorpej else \ 3391.1Sthorpej : ; \ 3401.1Sthorpej fi \ 3411.1Sthorpej else \ 3421.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3431.1Sthorpej fi 3441.1Sthorpej 3451.1Sthorpej 3461.5Slukemprotocols.time: ${DIR}/protocols 3471.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3481.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3491.5Slukem ${.ALLSRC} | \ 3501.9Sabs ${SORT} | ${MAKEDBM} - protocols.bynumber; \ 3511.5Slukem ${SED} -e "/^#/d" -e s/#.*$$// ${.ALLSRC} | \ 3521.5Slukem ${AWK} '{print $$1, $$0; \ 3531.5Slukem for (i = 3;i <= NF;i++) print $$i,$$0}' | \ 3541.9Sabs ${SORT} | ${MAKEDBM} - protocols.byname; \ 3551.5Slukem ${TOUCH} ${.TARGET}; \ 3561.5Slukem ${ECHO} "updated protocols"; \ 3571.5Slukem if [ ! ${NOPUSH} ]; then \ 3581.5Slukem ${YPPUSH} -d ${DOMAIN} protocols.bynumber; \ 3591.5Slukem ${YPPUSH} -d ${DOMAIN} protocols.byname; \ 3601.5Slukem ${ECHO} "pushed protocols"; \ 3611.1Sthorpej else \ 3621.1Sthorpej : ; \ 3631.1Sthorpej fi \ 3641.1Sthorpej else \ 3651.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3661.1Sthorpej fi 3671.1Sthorpej 3681.1Sthorpej 3691.5Slukemrpc.time: ${DIR}/rpc 3701.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3711.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3721.5Slukem ${.ALLSRC} | \ 3731.9Sabs ${SORT} | ${MAKEDBM} - rpc.bynumber; \ 3741.5Slukem ${TOUCH} ${.TARGET}; \ 3751.5Slukem ${ECHO} "updated rpc"; \ 3761.5Slukem if [ ! ${NOPUSH} ]; then \ 3771.5Slukem ${YPPUSH} -d ${DOMAIN} rpc.bynumber; \ 3781.5Slukem ${ECHO} "pushed rpc"; \ 3791.1Sthorpej else \ 3801.1Sthorpej : ; \ 3811.1Sthorpej fi \ 3821.1Sthorpej else \ 3831.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3841.1Sthorpej fi 3851.1Sthorpej 3861.1Sthorpej 3871.5Slukemservices.time: ${DIR}/services 3881.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3891.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3901.5Slukem ${.ALLSRC} | \ 3911.9Sabs ${SORT} | ${MAKEDBM} - services.byname; \ 3921.5Slukem ${TOUCH} ${.TARGET}; \ 3931.5Slukem ${ECHO} "updated services"; \ 3941.5Slukem if [ ! ${NOPUSH} ]; then \ 3951.5Slukem ${YPPUSH} -d ${DOMAIN} services.byname; \ 3961.5Slukem ${ECHO} "pushed services"; \ 3971.5Slukem else \ 3981.5Slukem : ; \ 3991.5Slukem fi \ 4001.5Slukem else \ 4011.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 4021.5Slukem fi 4031.5Slukem 4041.5Slukem 4051.5Slukemnetid.time: ${DIR}/passwd ${DIR}/group ${DIR}/hosts ${DIR}/netid 4061.5Slukem -@${MKNETID} -q -d ${DOMAIN} -p ${DIR}/passwd -g ${DIR}/group -h \ 4071.5Slukem ${DIR}/hosts -m ${DIR}/netid | \ 4081.9Sabs ${SORT} | ${MAKEDBM} - netid.byname; \ 4091.5Slukem ${TOUCH} ${.TARGET}; \ 4101.5Slukem ${ECHO} "updated netid"; \ 4111.5Slukem if [ ! ${NOPUSH} ]; then \ 4121.5Slukem ${YPPUSH} -d ${DOMAIN} netid.byname; \ 4131.5Slukem ${ECHO} "pushed netid"; \ 4141.1Sthorpej else \ 4151.1Sthorpej : ; \ 4161.1Sthorpej fi 4171.1Sthorpej 4181.5Slukem 4191.6Slukemypservers.time: ${.CURDIR}/ypservers 4201.6Slukem -@${MAKEDBM} ypservers ypservers; \ 4211.6Slukem ${TOUCH} ${.TARGET}; \ 4221.5Slukem ${ECHO} "updated ypservers"; \ 4231.5Slukem if [ ! ${NOPUSH} ]; then \ 4241.5Slukem ${YPPUSH} -d ${DOMAIN} ypservers; \ 4251.5Slukem ${ECHO} "pushed ypservers"; \ 4261.2Sthorpej else \ 4271.2Sthorpej : ; \ 4281.2Sthorpej fi 4291.1Sthorpej 4301.5Slukem 4311.1Sthorpejpasswd: passwd.time 4321.1Sthorpejgroup: group.time 4331.1Sthorpejhosts: hosts.time 4341.10Sitojunipnodes: ipnodes.time 4351.5Slukemaliases: aliases.time 4361.17Shubertf.for MAP in ${AMDMAPS} 4371.17Shubertf${MAP}: ${MAP}.time 4381.17Shubertf.endfor # AMDMAPS 4391.1Sthorpejethers: ethers.time 4401.5Slukemnetgroup: netgroup.time 4411.1Sthorpejnetworks: networks.time 4421.1Sthorpejrpc: rpc.time 4431.1Sthorpejservices: services.time 4441.11Schristosshadow: shadow.time 4451.1Sthorpejprotocols: protocols.time 4461.1Sthorpejnetid: netid.time 4471.6Slukemypservers: ypservers.time 4481.5Slukem 4491.5Slukem${DIR}/passwd: 4501.5Slukem${DIR}/group: 4511.5Slukem${DIR}/hosts: 4521.13Sitojun${DIR}/mail/aliases: 4531.17Shubertf.for MAP in ${AMDMAPS} 4541.17Shubertf${AMDDIR}/${MAP}: 4551.17Shubertf.endfor # AMDMAPS 4561.5Slukem${DIR}/ethers: 4571.5Slukem${DIR}/master.passwd: 4581.5Slukem${DIR}/netgroup: 4591.5Slukem${DIR}/networks: 4601.5Slukem${DIR}/rpc: 4611.5Slukem${DIR}/services: 4621.5Slukem${DIR}/protocols: 4631.5Slukem${DIR}/netid: 464