Makefile.yp revision 1.7
11.7Slukem# $NetBSD: Makefile.yp,v 1.7 1997/11/18 00:37:23 lukem 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.5Slukem# Comment out the following if you don't need compatibility with 161.5Slukem# sites that don't support this feature 171.7Slukem# 181.7Slukem# XXX: `secure' maps are currently not supported by the system, 191.7Slukem# so do not set this to `no' for NetBSD 1.3 clients. 201.7Slukem# 211.5SlukemINSECURE?= yes 221.5Slukem 231.5Slukem 241.5SlukemYPDBDIR= /var/yp 251.5SlukemDIR= /etc 261.5SlukemAMDDIR= /etc/amd 271.5SlukemDOMAIN= "`/usr/bin/basename ${.CURDIR}`" 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.5SlukemSTDETHERS= /usr/sbin/stdethers 431.5SlukemSTDHOSTS= /usr/sbin/stdhosts 441.5SlukemTOUCH= /usr/bin/touch 451.5SlukemYPPUSH= /usr/sbin/yppush 461.5Slukem 471.1Sthorpej 481.2Sthorpej# We have a rule for ypservers, but we don't build it by default, since 491.2Sthorpej# it seldom changes (only when slaves are added/deleted). 501.2Sthorpej 511.5Slukemall: passwd aliases amd.home ethers group hosts netgroup networks rpc services protocols netid 521.5Slukem 531.5Slukem 541.5Slukempasswd.time: ${DIR}/master.passwd 551.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 561.5Slukem umask 077 ; \ 571.5Slukem if [ "${INSECURE}" != "yes" ]; then \ 581.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 | \ 591.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 601.5Slukem { print $$1, $$1":*:"$$3":"$$4":"$$5":"$$6":"$$7 }' -|\ 611.5Slukem ${MAKEDBM} - passwd.byname; \ 621.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 |\ 631.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 641.5Slukem { print $$3, $$1":*:"$$3":"$$4":"$$5":"$$6":"$$7 }' -|\ 651.5Slukem ${MAKEDBM} - passwd.byuid; \ 661.5Slukem else \ 671.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 | \ 681.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 691.5Slukem { print $$1, $$0 }' - | ${MAKEDBM} - passwd.byname; \ 701.5Slukem ${CAT} ${.ALLSRC} | ${CUT} -d: -f1-4,8-10 |\ 711.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 721.5Slukem { print $$3, $$0 }' - | ${MAKEDBM} - passwd.byuid; \ 731.5Slukem fi; \ 741.5Slukem ${CAT} ${.ALLSRC} | \ 751.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 761.5Slukem { print $$1, $$0 }' - | ${MAKEDBM_S} - master.passwd.byname; \ 771.5Slukem ${CAT} ${.ALLSRC} | \ 781.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 791.5Slukem { print $$3, $$0 }' - | ${MAKEDBM_S} - master.passwd.byuid; \ 801.5Slukem ${TOUCH} ${.TARGET}; \ 811.5Slukem ${ECHO} "updated passwd"; \ 821.5Slukem if [ ! ${NOPUSH} ]; then \ 831.5Slukem ${YPPUSH} -d ${DOMAIN} passwd.byname; \ 841.5Slukem ${YPPUSH} -d ${DOMAIN} passwd.byuid; \ 851.5Slukem ${YPPUSH} -d ${DOMAIN} master.passwd.byname; \ 861.5Slukem ${YPPUSH} -d ${DOMAIN} master.passwd.byuid; \ 871.5Slukem ${ECHO} "pushed passwd"; \ 881.5Slukem else \ 891.5Slukem : ; \ 901.5Slukem fi \ 911.5Slukem else \ 921.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 931.5Slukem fi 941.5Slukem 951.5Slukem 961.5Slukemaliases.time: ${DIR}/aliases 971.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 981.5Slukem ${CP} -p ${.ALLSRC} ${DOMAIN}-aliases; \ 991.5Slukem ${SENDMAIL} -bi -oA${PWD}/${DOMAIN}-aliases; \ 1001.5Slukem ${MAKEDBM} -u ${DOMAIN}-aliases | ${MAKEDBM} - mail.aliases; \ 1011.5Slukem ${MKALIAS} mail.aliases mail.byaddr; \ 1021.5Slukem ${TOUCH} ${.TARGET}; \ 1031.5Slukem ${RM} ${DOMAIN}-aliases.db ${DOMAIN}-aliases; \ 1041.5Slukem ${ECHO} "updated aliases"; \ 1051.5Slukem if [ ! ${NOPUSH} ]; then \ 1061.5Slukem ${YPPUSH} -d ${DOMAIN} mail.aliases; \ 1071.5Slukem ${YPPUSH} -d ${DOMAIN} mail.byaddr; \ 1081.5Slukem ${ECHO} "pushed aliases"; \ 1091.5Slukem else \ 1101.5Slukem : ; \ 1111.5Slukem fi \ 1121.5Slukem else \ 1131.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1141.5Slukem fi 1151.5Slukem 1161.1Sthorpej 1171.5Slukemamd.home.time: ${AMDDIR}/amd.home 1181.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1191.5Slukem ${SED} -e "s/#.*$$//" -e "/^$$/d" ${.ALLSRC} | \ 1201.5Slukem ${AWK} '{ \ 1211.5Slukem for (i = 1; i <= NF; i++) \ 1221.5Slukem if (i == NF) { \ 1231.5Slukem if (substr($$i, length($$i), 1) == "\\") { \ 1241.5Slukem printf("%s", \ 1251.5Slukem substr($$i, 1, length($$i) - 1)); \ 1261.5Slukem } \ 1271.5Slukem else \ 1281.5Slukem printf("%s\n", $$i); \ 1291.5Slukem } \ 1301.5Slukem else \ 1311.5Slukem printf("%s ", $$i); \ 1321.5Slukem }' | \ 1331.5Slukem ${MAKEDBM} - amd.home; \ 1341.5Slukem ${TOUCH} ${.TARGET}; \ 1351.5Slukem ${ECHO} "updated amd.home"; \ 1361.5Slukem if [ ! ${NOPUSH} ]; then \ 1371.5Slukem ${YPPUSH} -d ${DOMAIN} amd.home; \ 1381.5Slukem ${ECHO} "pushed amd.home"; \ 1391.1Sthorpej else \ 1401.1Sthorpej : ; \ 1411.1Sthorpej fi \ 1421.1Sthorpej else \ 1431.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1441.1Sthorpej fi 1451.1Sthorpej 1461.1Sthorpej 1471.5Slukemethers.time: ${DIR}/ethers 1481.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1491.5Slukem ${STDETHERS} ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 1501.5Slukem ${AWK} 'BEGIN { FS="\t"; OFS="\t"; } { print $$1, $$0 }' | \ 1511.5Slukem ${MAKEDBM} - ethers.byaddr; \ 1521.5Slukem ${STDETHERS} ${.ALLSRC} | \ 1531.5Slukem ${AWK} 'BEGIN { FS="\t"; OFS="\t"; } { print $$2, $$0 }' | \ 1541.5Slukem ${MAKEDBM} - ethers.byname; \ 1551.5Slukem ${TOUCH} ${.TARGET}; \ 1561.5Slukem ${ECHO} "updated ethers"; \ 1571.5Slukem if [ ! ${NOPUSH} ]; then \ 1581.5Slukem ${YPPUSH} -d ${DOMAIN} ethers.byaddr; \ 1591.5Slukem ${YPPUSH} -d ${DOMAIN} ethers.byname; \ 1601.5Slukem ${ECHO} "pushed ethers"; \ 1611.1Sthorpej else \ 1621.1Sthorpej : ; \ 1631.1Sthorpej fi \ 1641.1Sthorpej else \ 1651.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1661.1Sthorpej fi 1671.1Sthorpej 1681.5Slukem 1691.5Slukemgroup.time: ${DIR}/group 1701.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1711.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1721.5Slukem { print $$1, $$0 }' ${.ALLSRC} | \ 1731.5Slukem ${MAKEDBM} - group.byname; \ 1741.5Slukem ${AWK} 'BEGIN { FS=":"; OFS="\t"; } /^[a-zA-Z0-9_]/ \ 1751.5Slukem { print $$3, $$0 }' ${.ALLSRC} | \ 1761.5Slukem ${MAKEDBM} - group.bygid; \ 1771.5Slukem ${TOUCH} ${.TARGET}; \ 1781.5Slukem ${ECHO} "updated group"; \ 1791.5Slukem if [ ! ${NOPUSH} ]; then \ 1801.5Slukem ${YPPUSH} -d ${DOMAIN} group.byname; \ 1811.5Slukem ${YPPUSH} -d ${DOMAIN} group.bygid; \ 1821.5Slukem ${ECHO} "pushed group"; \ 1831.1Sthorpej else \ 1841.1Sthorpej : ; \ 1851.1Sthorpej fi \ 1861.1Sthorpej else \ 1871.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 1881.1Sthorpej fi 1891.1Sthorpej 1901.5Slukem 1911.5Slukemhosts.time: ${DIR}/hosts 1921.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 1931.5Slukem ${STDHOSTS} ${.ALLSRC} | ${SED} -e s/#.*$$// | \ 1941.5Slukem ${AWK} '{for (i = 2; i <= NF; i++) print $$i, $$0 }' | \ 1951.5Slukem ${MAKEDBM} - hosts.byname; \ 1961.5Slukem ${STDHOSTS} ${.ALLSRC} | \ 1971.5Slukem ${AWK} 'BEGIN { OFS="\t"; } { print $$1, $$0 }' | \ 1981.5Slukem ${MAKEDBM} - hosts.byaddr; \ 1991.5Slukem ${TOUCH} ${.TARGET}; \ 2001.5Slukem ${ECHO} "updated hosts"; \ 2011.5Slukem if [ ! ${NOPUSH} ]; then \ 2021.5Slukem ${YPPUSH} -d ${DOMAIN} hosts.byname; \ 2031.5Slukem ${YPPUSH} -d ${DOMAIN} hosts.byaddr; \ 2041.5Slukem ${ECHO} "pushed hosts"; \ 2051.1Sthorpej else \ 2061.1Sthorpej : ; \ 2071.1Sthorpej fi \ 2081.1Sthorpej else \ 2091.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2101.1Sthorpej fi 2111.1Sthorpej 2121.5Slukem 2131.5Slukemnetgroup.time: ${DIR}/netgroup 2141.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2151.5Slukem ${CAT} ${.ALLSRC} | ${MAKEDBM} - netgroup; \ 2161.5Slukem ${CAT} ${.ALLSRC} | ${REVNETGROUP} -u -f - | \ 2171.5Slukem ${MAKEDBM} - netgroup.byuser; \ 2181.5Slukem ${CAT} ${.ALLSRC} | ${REVNETGROUP} -h -f - | \ 2191.5Slukem ${MAKEDBM} - netgroup.byhost; \ 2201.5Slukem ${TOUCH} ${.TARGET}; \ 2211.5Slukem ${ECHO} "updated netgroup"; \ 2221.5Slukem if [ ! ${NOPUSH} ]; then \ 2231.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup; \ 2241.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup.byuser; \ 2251.5Slukem ${YPPUSH} -d ${DOMAIN} netgroup.byhost; \ 2261.5Slukem ${ECHO} "pushed netgroup"; \ 2271.1Sthorpej else \ 2281.1Sthorpej : ; \ 2291.1Sthorpej fi \ 2301.1Sthorpej else \ 2311.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2321.1Sthorpej fi 2331.1Sthorpej 2341.5Slukem 2351.5Slukemnetworks.time: ${DIR}/networks 2361.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2371.5Slukem ${SED} -e "/^#/d" -e s/#.*$$// ${.ALLSRC} | \ 2381.5Slukem ${AWK} '{print $$1, $$0; \ 2391.5Slukem for (i = 3;i <= NF;i++) print $$i,$$0}' | \ 2401.5Slukem ${MAKEDBM} - networks.byname; \ 2411.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 2421.5Slukem ${.ALLSRC} | \ 2431.5Slukem ${MAKEDBM} - networks.byaddr; \ 2441.5Slukem ${TOUCH} ${.TARGET}; \ 2451.5Slukem ${ECHO} "updated networks"; \ 2461.5Slukem if [ ! ${NOPUSH} ]; then \ 2471.5Slukem ${YPPUSH} -d ${DOMAIN} networks.byname; \ 2481.5Slukem ${YPPUSH} -d ${DOMAIN} networks.byaddr; \ 2491.5Slukem ${ECHO} "pushed networks"; \ 2501.1Sthorpej else \ 2511.1Sthorpej : ; \ 2521.1Sthorpej fi \ 2531.1Sthorpej else \ 2541.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2551.1Sthorpej fi 2561.1Sthorpej 2571.1Sthorpej 2581.5Slukemprotocols.time: ${DIR}/protocols 2591.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2601.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 2611.5Slukem ${.ALLSRC} | \ 2621.5Slukem ${MAKEDBM} - protocols.bynumber; \ 2631.5Slukem ${SED} -e "/^#/d" -e s/#.*$$// ${.ALLSRC} | \ 2641.5Slukem ${AWK} '{print $$1, $$0; \ 2651.5Slukem for (i = 3;i <= NF;i++) print $$i,$$0}' | \ 2661.5Slukem ${MAKEDBM} - protocols.byname; \ 2671.5Slukem ${TOUCH} ${.TARGET}; \ 2681.5Slukem ${ECHO} "updated protocols"; \ 2691.5Slukem if [ ! ${NOPUSH} ]; then \ 2701.5Slukem ${YPPUSH} -d ${DOMAIN} protocols.bynumber; \ 2711.5Slukem ${YPPUSH} -d ${DOMAIN} protocols.byname; \ 2721.5Slukem ${ECHO} "pushed protocols"; \ 2731.1Sthorpej else \ 2741.1Sthorpej : ; \ 2751.1Sthorpej fi \ 2761.1Sthorpej else \ 2771.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2781.1Sthorpej fi 2791.1Sthorpej 2801.1Sthorpej 2811.5Slukemrpc.time: ${DIR}/rpc 2821.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 2831.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 2841.5Slukem ${.ALLSRC} | \ 2851.5Slukem ${MAKEDBM} - rpc.bynumber; \ 2861.5Slukem ${TOUCH} ${.TARGET}; \ 2871.5Slukem ${ECHO} "updated rpc"; \ 2881.5Slukem if [ ! ${NOPUSH} ]; then \ 2891.5Slukem ${YPPUSH} -d ${DOMAIN} rpc.bynumber; \ 2901.5Slukem ${ECHO} "pushed rpc"; \ 2911.1Sthorpej else \ 2921.1Sthorpej : ; \ 2931.1Sthorpej fi \ 2941.1Sthorpej else \ 2951.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 2961.1Sthorpej fi 2971.1Sthorpej 2981.1Sthorpej 2991.5Slukemservices.time: ${DIR}/services 3001.5Slukem -@if [ -f ${.ALLSRC} ]; then \ 3011.5Slukem ${AWK} 'BEGIN { OFS="\t"; } $$1 !~ /^#/ { print $$2, $$0 }' \ 3021.5Slukem ${.ALLSRC} | \ 3031.5Slukem ${MAKEDBM} - services.byname; \ 3041.5Slukem ${TOUCH} ${.TARGET}; \ 3051.5Slukem ${ECHO} "updated services"; \ 3061.5Slukem if [ ! ${NOPUSH} ]; then \ 3071.5Slukem ${YPPUSH} -d ${DOMAIN} services.byname; \ 3081.5Slukem ${ECHO} "pushed services"; \ 3091.5Slukem else \ 3101.5Slukem : ; \ 3111.5Slukem fi \ 3121.5Slukem else \ 3131.5Slukem ${ECHO} "couldn't find ${.ALLSRC}"; \ 3141.5Slukem fi 3151.5Slukem 3161.5Slukem 3171.5Slukemnetid.time: ${DIR}/passwd ${DIR}/group ${DIR}/hosts ${DIR}/netid 3181.5Slukem -@${MKNETID} -q -d ${DOMAIN} -p ${DIR}/passwd -g ${DIR}/group -h \ 3191.5Slukem ${DIR}/hosts -m ${DIR}/netid | \ 3201.5Slukem ${MAKEDBM} - netid.byname; \ 3211.5Slukem ${TOUCH} ${.TARGET}; \ 3221.5Slukem ${ECHO} "updated netid"; \ 3231.5Slukem if [ ! ${NOPUSH} ]; then \ 3241.5Slukem ${YPPUSH} -d ${DOMAIN} netid.byname; \ 3251.5Slukem ${ECHO} "pushed netid"; \ 3261.1Sthorpej else \ 3271.1Sthorpej : ; \ 3281.1Sthorpej fi 3291.1Sthorpej 3301.5Slukem 3311.6Slukemypservers.time: ${.CURDIR}/ypservers 3321.6Slukem -@${MAKEDBM} ypservers ypservers; \ 3331.6Slukem ${TOUCH} ${.TARGET}; \ 3341.5Slukem ${ECHO} "updated ypservers"; \ 3351.5Slukem if [ ! ${NOPUSH} ]; then \ 3361.5Slukem ${YPPUSH} -d ${DOMAIN} ypservers; \ 3371.5Slukem ${ECHO} "pushed ypservers"; \ 3381.2Sthorpej else \ 3391.2Sthorpej : ; \ 3401.2Sthorpej fi 3411.1Sthorpej 3421.5Slukem 3431.1Sthorpejpasswd: passwd.time 3441.1Sthorpejgroup: group.time 3451.1Sthorpejhosts: hosts.time 3461.5Slukemaliases: aliases.time 3471.5Slukemamd.home: amd.home.time 3481.1Sthorpejethers: ethers.time 3491.5Slukemnetgroup: netgroup.time 3501.1Sthorpejnetworks: networks.time 3511.1Sthorpejrpc: rpc.time 3521.1Sthorpejservices: services.time 3531.1Sthorpejprotocols: protocols.time 3541.1Sthorpejnetid: netid.time 3551.6Slukemypservers: ypservers.time 3561.5Slukem 3571.5Slukem${DIR}/passwd: 3581.5Slukem${DIR}/group: 3591.5Slukem${DIR}/hosts: 3601.5Slukem${DIR}/aliases: 3611.5Slukem${AMDDIR}/amd.home: 3621.5Slukem${DIR}/ethers: 3631.5Slukem${DIR}/master.passwd: 3641.5Slukem${DIR}/netgroup: 3651.5Slukem${DIR}/networks: 3661.5Slukem${DIR}/rpc: 3671.5Slukem${DIR}/services: 3681.5Slukem${DIR}/protocols: 3691.5Slukem${DIR}/netid: 370