summaryrefslogtreecommitdiff
blob: 6b57370d25f7a92c11dddba9f8990aa396699e4c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
# Copyright 1999-2000 Gentoo Technologies, Inc.
# Distributed under the terms of the GNU General Public License, v2 or later
# Author Achim Gottinger <achim@gentoo.org>
# /home/cvsroot/gentoo-x86/net-fs/samba/samba-2.2.1a.ebuild,v 1.2 2001/07/25 03:20:35 lamer Exp
# $Header: /var/cvsroot/gentoo-x86/net-fs/samba/samba-2.2.1a.ebuild,v 1.7 2001/08/30 17:31:35 pm Exp $


S=${WORKDIR}/${P}
DESCRIPTION="Samba :)"
SRC_URI="http://us1.samba.org/samba/ftp/${P}.tar.gz"
HOMEPAGE="http://www.samba.org"

DEPEND="virtual/glibc sys-devel/autoconf
        cups? ( net-print/cups )
	pam? ( >=sys-libs/pam-0.72 )
	tcpd? ( >=sys-apps/tcp-wrappers-7.6 )
	ssl? ( >=dev-libs/openssl-0.9.6 )"

RDEPEND="virtual/glibc
        cups? ( net-print/cups )"

# PAM support can cause lots of problems. We want the admin of the box to
# do this on his own. There is a mailing list thread on samba-devel that's
# about 40 posts long about this
#		pam? ( >=sys-libs/pam-0.72 )"

src_unpack() {
    unpack ${A}
    if [ "`use afs`" ]; then
      cd ${S}
      cat ${FILESDIR}/patch.221a.10 | patch -p0
    fi
}

src_compile() { 
  local myconf
# Again same as above, PAM and Samba not good. Consult samba.org for
# details. Only enable if you KNOW what you're doing and you really really
# wanna venture down this path.
#  if [ "`use pam`" ]
#  then
#     myconf="--with-pam"
#  else
    myconf="--without-pam"
#  fi

# Samba doesn't seem to work well with ssl support but I'll add the check 
# anyway (otherwise it seems to be built with ssl if it finds it). This should # tested. I'll mail gentoo-dev and add a todo in wiki. /Hallski

#  if [ "`use ssl`" ]
#  then
#     myconf="${myconf} --with-ssl"
#  else
     myconf="${myconf} --without-ssl"
#  fi

  cd ${S}/source
  if [ ! "`use cups`" ] ; then
    cp configure.in configure.in.orig
    sed -e "s:AC_CHECK_LIB(cups,httpConnect)::" configure.in.orig > configure.in
    autoconf
  fi
  
  if [ "`use afs`" ]; then
    myconf="$myconf --with-afs"
  fi

  # Disabled automout support, because it failed
  # Added -lncurses for readline detection

  try ./configure --prefix=/usr \
	--sysconfdir=/etc/smb --localstatedir=/var/log --libdir=/etc/smb --sbindir=/usr/sbin \
	--without-automount --with-utmp --without-sambabook --with-netatalk --with-smbmount \
	--with-privatedir=/etc/smb/private --with-msdfs --with-vfs --with-spinlocks --with-lockdir=/var/run/smb --with-swatdir=/usr/share/swat \
	--with-mandir=/usr/share/man ${myconf} 
  try make
}

src_install() { 
	cd ${S}/source
	dodir /usr
	dodir /etc/smb
	dodir /usr/share/swat
	dodir /usr/share/doc/${PF}/html/book
	dodir /var/log
	dodir /var/run/smb
	try make install prefix=${D}/usr BASEDIR=${D}/usr LIBDIR=${D}/etc/smb VARDIR=${D}/var/log \
		PRIVATEDIR=${D}/etc/smb/private SWATDIR=${D}/usr/share/swat \
		LOCKDIR=${D}/var/lock SBINDIR=${D}/usr/sbin MANDIR=${D}/usr/share/man
	into /usr
	cd ${S}/source/script
        exeinto /usr/sbin
	doexe convert_smbpasswd mknissmbpasswd.sh mknissmbpwdtbl.sh
	doexe mksmbpasswd.sh smbtar
        cd ${S}
	dodoc COPYING Manifest README Roadmap WHATSNEW.txt
	cd ${S}/docs
	dodoc announce history samba.lsm THANKS 
	docinto reg
	dodoc *.reg
	docinto html
	dodoc htmldocs/*.html
	docinto html/book
	dodoc htmldocs/using_samba/*.html
	docinto html/book/gifs
	dodoc htmldocs/using_samba/gifs/*
	docinto html/book/figs
	dodoc htmldocs/using_samba/figs/*
	docinto faq
	dodoc faq/*.txt
	docinto html/faq
	dodoc faq/*.html
	docinto textdocs
	dodoc textdocs/*.txt textdocs/README*
	docinto print
	dodoc textdocs/*.{tex,ps,pdf} 
	docinto sgml/faq
	dodoc faq/*.sgml
	docinto sgml/docbook/faq
	dodoc docbook/faq/*.sgml
	docinto sgml/docbook/howto
	dodoc docbook/howto/*.sgml	
	docinto sgml/docbook/manpages
	dodoc docbook/manpages/*.sgml
	docinto sgml/docbook/projdoc
	dodoc docbook/projdoc/*.sgml
	insinto /usr/share/sgml/docbook/dbsgml
	doins docbook/dbsgml/*
	insinto /usr/share/sgml/docbook/dbsgml/ent
	doins docbook/dbsgml/ent/*
	cd ${S}
	cp -a examples ${D}/usr/share/doc/${PF}
	cp examples/smb.conf.default ${D}/etc/smb/smb.conf.eg
	
	exeinto /etc/rc.d/init.d
	doexe ${FILESDIR}/samba ${FILESDIR}/svc-samba
	diropts -m0700
	dodir /etc/smb/private

	#now, we move smbmount from /usr/sbin to /sbin, and rename it to mount.smbfs
	#this allows it to work perfectly with the standard Linux mount command
	# :)

	dodir /sbin
	mv ${D}/usr/bin/smbmount ${D}/sbin/mount.smbfs


	#supervise support
	local x
	for x in smbd nmbd
	do
		dodir /var/lib/supervise/services/${x}/log
		chmod +t ${D}/var/lib/supervise/services/${x}
		exeinto /var/lib/supervise/services/${x}
		newexe ${FILESDIR}/${x}-run run
		exeinto /var/lib/supervise/services/${x}/log
		newexe ${FILESDIR}/${x}-log run
	done

	rm -rf ${D}/usr/private
}

pkg_preinst() {
	if [ "$ROOT" = "/" ]
	then
		if [ -e /etc/rc.d/init.d/svc-samba ]
		then
			/etc/rc.d/init.d/svc-samba stop
		fi
		if [ -e /etc/rc.d/init.d/samba ]
		then
			/etc/rc.d/init.d/samba stop
		fi
	fi
}

pkg_postinst() {
	#touch ${D}/etc/smb/smb.conf to create a dummy file so that people installing samba
	#just to mount smb shares don't get annoying warnings all the time

	if [ ! -e ${ROOT}etc/smb/smb.conf ]
	then
		touch ${ROOT}etc/smb/smb.conf
	fi
	
	echo "Samba installed.  To configure samba (the server) to start on boot, type:"
	echo
	echo "# rc-update add svc-samba    [ for high-availability supervised Samba -- recommended ]"
	echo "# rc-update add samba		[ for normal non-supervised Samba ]"
	echo 
	echo "If you had samba running earlier, you'll need to start it again."
	echo 
	echo "Also, please note that you must configure /etc/smb/smb.conf before Samba (the server) will "
	echo "work properly.  Mounting smb shares and the smbclient program should work immediately,"
	echo "without any tweaking required."
	echo
	echo "To mount SMB shares, type something like this.  You'll need kernel SMB support to do this:"
	echo "# mount -t smbfs -o username=drobbins,password=foo,ip=192.168.1.1 //mybox/drobbins /mnt/foo" 
	echo
	echo "An empty file exists at /etc/smb/smb.conf at this moment, so that mounting smb shares won't"
	echo "produce an annoying warning message."
	echo
	echo "Another note.  If you want to allow normal users to mount smb shares, type the following as"
	echo "root:"
	echo "# chmod u+s /usr/bin/smbmnt"
}