2 # This script is used by the debian and RPM packages to set up fusionforge.
5 echo "$0: [-interact] [-help] [-debug] [-confdir confdir] [-input conffile] [-output conffile] [-httpdconf gforgehttpdconf] [-httpdsecrets gforgehttpdsecrets] [-localinc gforgelocalinc] [-example|-fhs] [-clean] [-noapache] [-dovhost] [-home homepath] [-group grouppath] [-listen80|nolisten80] [-nossl]"
14 echo "Calculating defaults"
15 # This is used to make a default working gforge.conf
16 DEFAULTsystem_name=MyGForge
17 DEFAULTdomain_name=`hostname -f`
18 DEFAULTserver_admin=webmaster@$DEFAULTdomain_name
19 DEFAULTdb_host=`hostname -i`
23 DEFAULTdb_password=$(dd if=/dev/urandom count=256 bs=1 2> /dev/null | md5sum | cut -b1-8)
24 DEFAULTip_address=`hostname -i`
25 DEFAULTscm_host=scm.$DEFAULTdomain_name
26 DEFAULTshell_host=shell.$DEFAULTdomain_name
27 DEFAULTusers_host=users.$DEFAULTdomain_name
28 DEFAULTlists_host=lists.$DEFAULTdomain_name
29 # The following three have to be synced when domain_name changes
30 # and docs_host is supposed not to be used
31 #DEFAULTdocs_host=gfdocs.$DEFAULTdomain_name
32 DEFAULTjabber_host=jabber.$DEFAULTdomain_name
33 DEFAULTupload_host=upload.$DEFAULTdomain_name
35 DEFAULTdownload_host=download.$DEFAULTdomain_name
36 # The following is upload host and dir for FRS
37 DEFAULTftpuploadhost=upload.$DEFAULTdomain_name
38 DEFAULTftpuploaddir=$GFGDIR/var/lib/gforge/chroot/ftproot
40 DEFAULTstatsadmin_groupid=2
41 DEFAULTnewsadmin_groupid=3
42 DEFAULTpeerrating_groupid=4
43 DEFAULTtemplate_project=5
44 DEFAULTadmin_login=admin
45 DEFAULTadmin_password=$(dd if=/dev/urandom count=256 bs=1 2> /dev/null | md5sum | cut -b1-8)
46 DEFAULTskill_list="Ada;C;C++;HTML;LISP;Perl;PHP;Python;SQL"
47 DEFAULTdefault_trove_cat=18
48 DEFAULTldap_host=localhost
49 DEFAULTldap_base_dn="dc=`echo $DEFAULTdomain_name | sed 's/\./,dc=/g'`"
50 DEFAULTldap_web_add_password=$(dd if=/dev/urandom count=256 bs=1 2> /dev/null | md5sum | cut -b1-8)
51 DEFAULTsys_path_to_mailman=$(if test -d /usr/lib/mailman; then echo /usr/lib/mailman; else echo /var/mailman; fi)
53 DEFAULTcronolog_path=$(findcronolog)
54 DEFAULTsys_sendmail_path=$(findsendmail)
55 DEFAULTsys_path_to_jpgraph=/usr/share/jpgraph/
56 DEFAULTsys_path_to_scmweb=/usr/share/gforge/bin/
57 DEFAULTgforge_chroot=$CHROOT
58 DEFAULTgforge_etc=$ETCDIR
59 DEFAULTsys_custom_path=$ETCDIR/custom
60 DEFAULTgroupdir=$GROUPPATH
61 DEFAULThomedir=$HOMEPATH
62 DEFAULTcvsdir=$CVSPATH
63 DEFAULTsvndir=$SVNPATH
64 # The place where file uploaded with http are stored for download
65 DEFAULTuploaddir=$GFGDIR/var/lib/gforge/download/
66 DEFAULTsys_urlroot=$SHAREDIR/www/
67 DEFAULTsys_jabber_pass=$(dd if=/dev/urandom count=256 bs=1 2> /dev/null | md5sum | cut -b1-8)
68 DEFAULTusr_share_gforge=$SHAREDIR
69 DEFAULTusr_lib_gforge=$LIBDIR
70 DEFAULTvar_lib_gforge=$GFGDIR/var/lib/gforge
71 DEFAULTvar_log_gforge=$GFGDIR/var/log/gforge
72 DEFAULTsys_show_source=0
73 DEFAULTsys_force_login=0
74 DEFAULTsys_session_key=$(dd if=/dev/urandom count=256 bs=1 2> /dev/null | md5sum | cut -b1-32)
75 DEFAULTsys_session_expire='60 * 60 * 24 * 7'
76 DEFAULTsys_show_contact_info=1
77 DEFAULTsys_themeroot=$SHAREDIR/www/themes/
78 DEFAULTsys_theme=gforge
79 DEFAULTsys_lang=English
80 DEFAULTsys_default_timezone=GMT
81 DEFAULTsys_default_country_code=US
82 DEFAULTsys_account_manager_type=$SYSTEM
83 DEFAULTsys_use_jabber=0
84 DEFAULTsys_use_auth_ldap=1
85 # Couldn't find where this is used, maybe some rest of ext auth
86 #DEFAULTsys_ldap_auth_host=localhost
87 DEFAULTsys_ldap_auth_port=389
88 DEFAULTsys_ldap_auth_version=3
89 DEFAULTsys_ldap_auth_dn="dc=`echo $DEFAULTdomain_name | sed 's/\./,dc=/g'`"
90 DEFAULTsys_scm_tarballs_path=$GFGDIR/var/lib/gforge/scmtarballs
91 DEFAULTsys_scm_snapshots_path=$GFGDIR/var/lib/gforge/scmsnapshots
92 DEFAULTsys_use_scm=true
93 DEFAULTsys_use_tracker=true
94 DEFAULTsys_use_forum=true
95 DEFAULTsys_use_pm=true
96 DEFAULTsys_use_docman=true
97 DEFAULTsys_use_news=true
98 DEFAULTsys_use_mail=true
99 DEFAULTsys_use_survey=true
100 DEFAULTsys_use_frs=true
101 DEFAULTsys_use_fti=false
102 DEFAULTsys_use_ftp=true
103 DEFAULTsys_use_trove=true
104 DEFAULTsys_use_snippet=true
105 DEFAULTsys_use_shell=true
106 DEFAULTsys_use_ratings=true
107 DEFAULTsys_use_ssl=false
108 DEFAULTsys_use_people=true
109 DEFAULTsys_use_ftpuploads=false
110 DEFAULTsys_use_diary=true
111 DEFAULTsys_use_bookmarks=true
112 DEFAULTsys_use_project_tags=true
113 DEFAULTsys_use_project_full_list=true
114 DEFAULTsys_use_gateways=true
115 DEFAULTsys_use_project_vhost=true
116 DEFAULTsys_use_project_database=false
117 DEFAULTsys_use_project_multimedia=false
118 DEFAULTsys_use_private_project=true
119 DEFAULTsys_project_reg_restricted=false
120 DEFAULTsys_user_reg_restricted=false
121 DEFAULTsys_require_accept_conditions=false
122 DEFAULTsys_require_unique_email=false
123 DEFAULTsys_localinc=$ETCDIR/local.inc
124 DEFAULTsys_jabber_pass=$(dd if=/dev/urandom count=256 bs=1 2> /dev/null | md5sum | cut -b1-8)
125 DEFAULTsys_plugins_path=$SHAREDIR/plugins/
126 DEFAULTsys_sslcrt=$(findcrt)
127 DEFAULTsys_sslkey=$(findkey)
128 DEFAULTnoreply_to_bitbucket=true
129 DEFAULTsys_simple_dns=true
130 DEFAULTsys_apache_user=$(findapacheowner)
131 DEFAULTsys_apache_group=$(findapacheowner)
132 DEFAULTsys_forum_return_domain=$DEFAULTdomain_name
133 DEFAULTsys_block_anonymous_downloads=false
134 DEFAULTsys_urlprefix=/
137 #usr_lib_gforge=$GFGDIR
143 if [ -e /etc/gforge/ssl-cert.pem ] ; then
144 echo /etc/gforge/ssl-cert.pem
145 elif [ -f /etc/apache2/ssl/apache.pem ] ; then
146 echo /etc/apache2/ssl/apache.pem
147 elif [ -f /etc/apache/ssl.crt/server.crt ] ; then
148 echo /etc/apache/ssl.crt/server.crt
152 if [ -e /etc/gforge/ssl-cert.key ] ; then
153 echo /etc/gforge/ssl-cert.key
154 elif [ -f /etc/apache2/ssl/apache.pem ] ; then
155 echo /etc/apache2/ssl/apache.pem
156 elif [ -f /etc/apache/ssl.key/server.key ] ; then
157 echo /etc/apache/ssl.key/server.key
161 if [ -x /usr/bin/cronolog ]
163 echo /usr/bin/cronolog
165 if [ -x /usr/sbin/cronolog ]
167 echo /usr/sbin/cronolog
174 if [ -x /usr/sbin/sendmail ]
176 echo /usr/sbin/sendmail
182 if grep 'Red Hat' /etc/issue > /dev/null; then
184 elif grep SuSE /etc/issue > /dev/null; then
186 elif grep Debian /etc/issue > /dev/null; then
195 # This create a default conf file in $1
196 tmpfile=$1.$$computedefault
197 echo "cat >$1<<-EOF" > $tmpfile
198 cat $0 | grep "^ DEFAULT" | sed 's/ DEFAULT\(.[^=]*\)=.*/\1=\${\1:-\$DEFAULT\1}/' >> $tmpfile
199 echo 'EOF' >> $tmpfile
205 cat $1 | sed 's/\(.[^=]*\)=\(.*\)/DEFAULT\1="\2"/' |
206 grep -v '^DEFAULTcronolog_path' > $1.$$readdefault
209 if [ ! -z "$DEFAULTsys_sslcrt" -a ! -f "$DEFAULTsys_sslcrt" ]
211 unset DEFAULTsys_sslcrt
212 DEFAULTsys_sslcrt=$(findcrt)
214 if [ -z "$DEFAULTsys_sslcrt" ]
216 DEFAULTsys_sslcrt=$(findcrt)
219 if [ ! -z "$DEFAULTsys_sslkey" -a ! -f "$DEFAULTsys_sslkey" ]
221 unset DEFAULTsys_sslkey
222 DEFAULTsys_sslkey=$(findkey)
224 if [ -z "$DEFAULTsys_sslkey" ]
226 DEFAULTsys_sslkey=$(findkey)
229 if [ ! -d "$DEFAULTsys_themeroot/$DEFAULTsys_theme" ]
231 if [ -d "$DEFAULTsys_themeroot/gforge" ]
233 DEFAULTsys_theme=gforge
236 rm -f $1.$$readdefault
243 writedefault $CONFFILEIN.new
245 if [ -f $CONFFILEIN ]
247 echo "Reading defaults from $CONFFILEIN"
248 readdefault $CONFFILEIN
250 readdefault $CONFFILEIN.new
253 if [ "$interact" = true ]
255 echo "Enter values or type enter for defaults:"
257 # This ask for change of default
259 cat $0 | grep "^ DEFAULT" | sed 's/ DEFAULT\(.[^=]*\)=.*/getval \1 "\${DEFAULT\1}"/' > $tmpfile
261 cat $0 | grep "^ DEFAULT" | sed 's/ DEFAULT\(.[^=]*\)=.*/\1="\${DEFAULT\1}"/' > $tmpfile
266 echo "Creating $CONFFILEOUT"
267 [ ! -d `dirname $CONFFILEOUT` ] && (mkdir -p `dirname $CONFFILEOUT` || (echo "Could not create `dirname $CONFFILEOUT`" && exit 1))
268 writedefault $CONFFILEOUT.new
269 mv $CONFFILEOUT.new $CONFFILEOUT
272 # Remove trailing space
273 cat $CONFFILEIN | sed 's/ *$//' > $CONFFILEIN.new
274 mv $CONFFILEIN.new $CONFFILEIN
277 EXCLUDEVHOST=' -not -name 55vhost'
278 if [ "$dovhost" = true ]
283 rm -f $ETCDIR/httpd.d/10cvs
284 rm -f $ETCDIR/httpd.d/10scmcvs
285 rm -f $ETCDIR/httpd.d/10scmcvsauth
286 rm -f $ETCDIR/httpd.d/07maindirhttps
287 rm -f $ETCDIR/httpd.d/11scmcvshttp
288 rm -f $ETCDIR/httpd.d/11scmsvnhttp
289 rm -f $ETCDIR/httpd.d/12scmcvshttp.ssl
290 #rm -f $ETCDIR/httpd.d/20list
293 find $ETCTEMPLATEDIR/httpd.d -follow -type f -regex "$ETCTEMPLATEDIR/httpd.d/\([a-z0-9]+\|_?([a-z0-9_.]+-)+[a-z0-9]+\|[a-z0-9][a-z0-9-]*\)\(\|.ssl\|.secrets\)" $EXCLUDEVHOST | sort | while read i
295 if [ "$ETCTEMPLATEDIR" != "$ETCDIR" -a -f $ETCDIR/httpd.d/`basename $i` ]
297 if diff -q $i $ETCDIR/httpd.d/`basename $i`
299 rm -f $ETCDIR/httpd.d/`basename $i`
301 i=$ETCDIR/httpd.d/`basename $i`
304 $BINDIR/fill-in-the-blanks.pl $i $ETCDIR/`basename $i`.gforge-new $CONFFILEOUT
307 if [ $listen80 = false ]
309 rm -f $ETCDIR/00listen80.gforge-new
312 if [ $usessl = false -o -z "$(findkey)" -o -z "$(findcrt)" ]
315 rm -f $ETCDIR/[0-9][0-9]*.ssl.gforge-new
320 echo "Creating $HTTPDCONF"
321 ls $ETCDIR/[0-9][0-9]*.gforge-new | sort | xargs cat > $HTTPDCONF
322 rm $ETCDIR/[0-9][0-9]*.gforge-new
323 echo "Creating $HTTPDSECRETS"
324 cat $ETCDIR/httpd.secrets.gforge-new > $HTTPDSECRETS
325 rm $ETCDIR/httpd.secrets.gforge-new
327 echo "Creating $LOCALINC"
328 find $ETCTEMPLATEDIR/local.d -follow -type f -regex "$ETCTEMPLATEDIR/local.d/\([a-z0-9]+\|_?([a-z0-9_.]+-)+[a-z0-9]+\|[a-z0-9][a-z0-9-]*\)\(\|.$database\)" | sort | while read i
330 if [ "$ETCTEMPLATEDIR" != "$ETCDIR" -a -f $ETCDIR/local.d/`basename $i` ]
332 if diff -q $i $ETCDIR/local.d/`basename $i`
334 rm -f $ETCDIR/local.d/`basename $i`
336 i=$ETCDIR/local.d/`basename $i`
339 $BINDIR/fill-in-the-blanks.pl $i $CONFFILEOUTDIR/`basename $i` $CONFFILEOUT
341 (find $CONFFILEOUTDIR -follow -type f -regex "$CONFFILEOUTDIR/\([a-z0-9]+\|_?([a-z0-9_.]+-)+[a-z0-9]+\|[a-z0-9][a-z0-9-]*\)\(\|.$database\)" | sort | xargs cat ) > $LOCALINC
342 find $CONFFILEOUTDIR -follow -type f -regex "$CONFFILEOUTDIR/\([a-z0-9]+\|_?([a-z0-9_.]+-)+[a-z0-9]+\|[a-z0-9][a-z0-9-]*\)\(\|.$database\)" -print0 | xargs -0 rm
344 echo "Creating other includes"
345 #for i in $ETCDIR/templates/[a-z]*
346 find $ETCTEMPLATEDIR/templates -follow -type f -regex "$ETCTEMPLATEDIR/templates/[a-z].*" | while read i
348 if [ "$ETCTEMPLATEDIR" != "$ETCDIR" -a -f $ETCDIR/templates/`basename $i` ]
350 if diff -q $i $ETCDIR/templates/`basename $i`
352 rm -f $ETCDIR/templates/`basename $i`
354 i=$ETCDIR/templates/`basename $i`
357 $BINDIR/fill-in-the-blanks.pl $i $CONFFILEOUTDIR/`basename $i` $CONFFILEOUT
359 chmod 600 $HTTPDSECRETS $CONFFILEIN $CONFFILEOUT
360 chmod 640 $CONFFILEOUTDIR/local.pl $CONFFILEOUTDIR/database.inc
361 chown gforge:gforge $CONFFILEOUTDIR/local.pl $CONFFILEOUTDIR/database.inc
365 APACHECONF=/etc/apache/httpd.conf
366 GFORGE_ETC_SEARCH=$HTTPDCONF
367 export GFORGE_ETC_SEARCH
368 if [ -f $APACHECONF -a -f $BINDIR/install-apache.sh ] ; then
369 if [ ! -f /etc/apache/conf.d/gforge.httpd.conf ] ; then
370 if ! grep -q "^Include $GFORGE_ETC_SEARCH" $APACHECONF ; then
371 $BINDIR/install-apache.sh setup
373 echo "Found Include $GFORGE_ETC_SEARCH in $APACHECONF"
376 LINK=`ls -l /etc/apache/conf.d/gforge.httpd.conf | sed 's/.*-> \(.*\)$/\1/'`
377 if [ "$LINK" != "$GFORGE_ETC_SEARCH" ] ; then
378 echo Need to readjust Symlink
379 $BINDIR/install-apache.sh setup
381 if ! grep -q "^Include $GFORGE_ETC_SEARCH" $APACHECONF ; then
382 echo "Found /etc/apache/conf.d/gforge.httpd.conf"
384 # There is a link and an include
385 $BINDIR/install-apache.sh setup
393 ETCTEMPLATEDIR=`pwd`/etc
399 GROUPPATH=/home/groups
401 if [ ! -e /cvsroot ] && [ -e /var/lib/gforge/chroot/cvsroot ] ; then
402 CVSPATH=/var/lib/gforge/chroot/cvsroot
405 if [ ! -e /svnroot ] && [ -e /var/lib/gforge/chroot/svnroot ] ; then
406 SVNPATH=/var/lib/gforge/chroot/svnroot
410 CONFFILEOUTDIR=$ETCDIR
411 CONFFILEIN=$ETCDIR/gforge.conf
412 CONFFILEOUT=$ETCDIR/gforge.conf
413 LOCALINC=$ETCDIR/local.inc
414 HTTPDCONF=$ETCDIR/httpd.conf
415 HTTPDSECRETS=$ETCDIR/httpd.secrets
417 export ETCDIR ETCTEMPLATEDIR BINDIR GFGDIR CONFFILEOUTDIR CONFFILEIN CONFFILEOUT LOCALINC HTTPDCONF HTTPDSECRETS DOAPACHE SYSTEM
462 CONFFILEIN=$1/gforge.conf
463 CONFFILEOUT=$1/gforge.conf
464 LOCALINC=$1/local.inc
465 HTTPDCONF=$1/httpd.conf
466 HTTPDSECRETS=$1/httpd.secrets
467 echo Using $1 as config directory
472 ETCTEMPLATEDIR=/usr/share/gforge/etc
473 BINDIR=/usr/share/gforge/bin
474 CGIDIR=/usr/share/gforge/cgi-bin
477 GROUPPATH=/home/groups
478 CHROOT=/var/lib/gforge/chroot
479 SHAREDIR=/usr/share/gforge
480 LIBDIR=/usr/share/gforge
481 CONFFILEOUTDIR=/etc/gforge
482 CONFFILEIN=/etc/gforge/gforge.conf
483 CONFFILEOUT=/etc/gforge/gforge.conf
484 LOCALINC=/etc/gforge/local.inc
485 HTTPDCONF=/etc/gforge/httpd.conf
486 HTTPDSECRETS=/etc/gforge/httpd.secrets
508 CONFFILEIN=$ETCDIR/gforge.conf.example
509 CONFFILEOUT=$ETCDIR/gforge.conf.example
510 LOCALINC=$ETCDIR/local.inc.example
511 HTTPDCONF=$ETCDIR/httpd.conf.example
512 HTTPDSECRETS=$ETCDIR/httpd.secrets.example
525 [ -f $CONFFILEIN ] && echo Removing $CONFFILEIN && rm -f $CONFFILEIN
526 [ -f $CONFFILEOUT ] && echo Removing $CONFFILEOUT && rm -f $CONFFILEOUT
527 [ -f $LOCALINC ] && echo Removing $LOCALINC && rm -f $LOCALINC
528 [ -f $HTTPDCONF ] && echo Removing $HTTPDCONF && rm -f $HTTPDCONF
529 [ -f $HTTPDSECRETS ] && echo Removing $HTTPDSECRETS && rm -f $HTTPDSECRETS
544 [ "$noapache" != true ] && doapache