1 PACKAGES += cifs-utils libpam-mount libpam-script lxdm nis nscd samba-common-bin usermode
4 nis_server := nismaster
9 nis nis/domain string .${nis_server}
12 export smb_nis_pamscript smb_nis_pammount
14 define smb_nis_pamscript :=
18 printf "%s\n" "$$PAM_OLDAUTHTOK" "$$PAM_AUTHTOK" "$$PAM_AUTHTOK" \
19 | smbpasswd -sr ${nis_server} -U "$$PAM_USER"
26 define smb_nis_pammount :=
27 <pam_mount> <debug enable="0" />
28 <!-- Volume definitions -->
29 <volume options="user=%(USER)" fstype="cifs" server="${nis_server}" path="%(USER)" mountpoint="~" />
30 <mntoptions require="nosuid,nodev" />
31 <logout wait="0" hup="no" term="no" kill="no" />
32 <mkmountpoint enable="1" remove="true" />
40 _smb_nis: ${CFGROOT}/opt/pam_script/pam_script_passwd ${CFGROOT}/etc/security/pam_mount.conf.xml
41 _smb_nis: ${CFGROOT}/etc/yp.conf ${CFGROOT}/etc/defaultdomain
44 sed -Ei 's;^(passwd:|group:|shadow:|gshadow:) *;\1 nis ;' $${CFGROOT}/etc/nsswitch.conf
45 printf '\nauth optional pam_mount.so\n' >>$${CFGROOT}/etc/pam.d/common-auth
46 printf '\nsession optional pam_mount.so\n' >>$${CFGROOT}/etc/pam.d/common-session
47 printf '\npassword required pam_script.so dir=/opt/pam_script\n' >$${CFGROOT}/etc/pam.d/common-password
49 ${CFGROOT}/opt/pam_script/pam_script_passwd: ${CFGROOT}
51 printf '%s' "$${smb_nis_pamscript}" >"$@"
53 ${CFGROOT}/etc/security/pam_mount.conf.xml: ${CFGROOT}
55 printf '%s' "$${smb_nis_pammount}" >"$@"
57 ${CFGROOT}/etc/yp.conf: ${CFGROOT}
58 printf 'ypserver %s\n' "${nis_server}" >"$@"
60 ${CFGROOT}/etc/defaultdomain: ${CFGROOT}
61 printf '.%s\n' "${nis_server}" >"$@"