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] [-novhost] [-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 DEFAULTnewsadmin_groupid=2
41 DEFAULTstatsadmin_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=/
135 DEFAULTdovhost=$dovhost
138 #usr_lib_gforge=$GFGDIR
144 if [ -e /etc/gforge/ssl-cert.pem ] ; then
145 echo /etc/gforge/ssl-cert.pem
146 elif [ -f /etc/apache2/ssl/apache.pem ] ; then
147 echo /etc/apache2/ssl/apache.pem
148 elif [ -f /etc/apache/ssl.crt/server.crt ] ; then
149 echo /etc/apache/ssl.crt/server.crt
153 if [ -e /etc/gforge/ssl-cert.key ] ; then
154 echo /etc/gforge/ssl-cert.key
155 elif [ -f /etc/apache2/ssl/apache.pem ] ; then
156 echo /etc/apache2/ssl/apache.pem
157 elif [ -f /etc/apache/ssl.key/server.key ] ; then
158 echo /etc/apache/ssl.key/server.key
162 if [ -x /usr/bin/cronolog ]
164 echo /usr/bin/cronolog
166 if [ -x /usr/sbin/cronolog ]
168 echo /usr/sbin/cronolog
175 if [ -x /usr/sbin/sendmail ]
177 echo /usr/sbin/sendmail
183 if grep 'Red Hat' /etc/issue > /dev/null; then
185 elif grep SuSE /etc/issue > /dev/null; then
187 elif grep Debian /etc/issue > /dev/null; then
196 # This create a default conf file in $1
197 tmpfile=$1.$$computedefault
198 echo "cat >$1<<-EOF" > $tmpfile
199 cat $0 | grep "^ DEFAULT" | sed 's/ DEFAULT\(.[^=]*\)=.*/\1=\${\1:-\$DEFAULT\1}/' >> $tmpfile
200 echo 'EOF' >> $tmpfile
206 cat $1 | sed 's/\(.[^=]*\)=\(.*\)/DEFAULT\1="\2"/' |
207 grep -v '^DEFAULTcronolog_path' > $1.$$readdefault
210 if [ ! -z "$DEFAULTsys_sslcrt" -a ! -f "$DEFAULTsys_sslcrt" ]
212 unset DEFAULTsys_sslcrt
213 DEFAULTsys_sslcrt=$(findcrt)
215 if [ -z "$DEFAULTsys_sslcrt" ]
217 DEFAULTsys_sslcrt=$(findcrt)
220 if [ ! -z "$DEFAULTsys_sslkey" -a ! -f "$DEFAULTsys_sslkey" ]
222 unset DEFAULTsys_sslkey
223 DEFAULTsys_sslkey=$(findkey)
225 if [ -z "$DEFAULTsys_sslkey" ]
227 DEFAULTsys_sslkey=$(findkey)
230 if [ ! -d "$DEFAULTsys_themeroot/$DEFAULTsys_theme" ]
232 if [ -d "$DEFAULTsys_themeroot/gforge" ]
234 DEFAULTsys_theme=gforge
237 rm -f $1.$$readdefault
244 writedefault $CONFFILEIN.new
246 if [ -f $CONFFILEIN ]
248 echo "Reading defaults from $CONFFILEIN"
249 readdefault $CONFFILEIN
251 readdefault $CONFFILEIN.new
254 if [ "$interact" = true ]
256 echo "Enter values or type enter for defaults:"
258 # This ask for change of default
260 cat $0 | grep "^ DEFAULT" | sed 's/ DEFAULT\(.[^=]*\)=.*/getval \1 "\${DEFAULT\1}"/' > $tmpfile
262 cat $0 | grep "^ DEFAULT" | sed 's/ DEFAULT\(.[^=]*\)=.*/\1="\${DEFAULT\1}"/' > $tmpfile
267 echo "Creating $CONFFILEOUT"
268 [ ! -d `dirname $CONFFILEOUT` ] && (mkdir -p `dirname $CONFFILEOUT` || (echo "Could not create `dirname $CONFFILEOUT`" && exit 1))
269 writedefault $CONFFILEOUT.new
270 mv $CONFFILEOUT.new $CONFFILEOUT
273 # Remove trailing space
274 cat $CONFFILEIN | sed 's/ *$//' > $CONFFILEIN.new
275 mv $CONFFILEIN.new $CONFFILEIN
279 if [ "$dovhost" = true ]
281 EXCLUDEVHOST=".vhost\|"
284 rm -f $ETCDIR/httpd.d/10cvs
285 rm -f $ETCDIR/httpd.d/10scmcvs
286 rm -f $ETCDIR/httpd.d/10scmcvsauth
287 rm -f $ETCDIR/httpd.d/07maindirhttps
288 rm -f $ETCDIR/httpd.d/11scmcvshttp
289 rm -f $ETCDIR/httpd.d/11scmsvnhttp
290 rm -f $ETCDIR/httpd.d/12scmcvshttp.ssl
291 #rm -f $ETCDIR/httpd.d/20list
294 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.vhost.ssl\)" | sort | while read i
296 if [ "$ETCTEMPLATEDIR" != "$ETCDIR" -a -f $ETCDIR/httpd.d/`basename $i` ]
298 if diff -q $i $ETCDIR/httpd.d/`basename $i`
300 rm -f $ETCDIR/httpd.d/`basename $i`
302 i=$ETCDIR/httpd.d/`basename $i`
305 $BINDIR/fill-in-the-blanks.pl $i $ETCDIR/`basename $i`.gforge-new $CONFFILEOUT
308 if [ $listen80 = false ]
310 rm -f $ETCDIR/00listen80.gforge-new
313 if [ $usessl = false -o -z "$(findkey)" -o -z "$(findcrt)" ]
316 rm -f $ETCDIR/[0-9][0-9]*.ssl.gforge-new
321 echo "Creating $HTTPDCONF"
322 ls $ETCDIR/[0-9][0-9]*.gforge-new | sort | xargs cat > $HTTPDCONF
323 rm $ETCDIR/[0-9][0-9]*.gforge-new
324 echo "Creating $HTTPDSECRETS"
325 cat $ETCDIR/httpd.secrets.gforge-new > $HTTPDSECRETS
326 rm $ETCDIR/httpd.secrets.gforge-new
328 echo "Creating $LOCALINC"
329 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
331 if [ "$ETCTEMPLATEDIR" != "$ETCDIR" -a -f $ETCDIR/local.d/`basename $i` ]
333 if diff -q $i $ETCDIR/local.d/`basename $i`
335 rm -f $ETCDIR/local.d/`basename $i`
337 i=$ETCDIR/local.d/`basename $i`
340 $BINDIR/fill-in-the-blanks.pl $i $CONFFILEOUTDIR/`basename $i` $CONFFILEOUT
342 (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
343 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
345 echo "Creating other includes"
346 #for i in $ETCDIR/templates/[a-z]*
347 find $ETCTEMPLATEDIR/templates -follow -type f -regex "$ETCTEMPLATEDIR/templates/[a-z].*" | while read i
349 if [ "$ETCTEMPLATEDIR" != "$ETCDIR" -a -f $ETCDIR/templates/`basename $i` ]
351 if diff -q $i $ETCDIR/templates/`basename $i`
353 rm -f $ETCDIR/templates/`basename $i`
355 i=$ETCDIR/templates/`basename $i`
358 $BINDIR/fill-in-the-blanks.pl $i $CONFFILEOUTDIR/`basename $i` $CONFFILEOUT
360 chmod 600 $HTTPDSECRETS $CONFFILEIN $CONFFILEOUT
361 chmod 640 $CONFFILEOUTDIR/local.pl $CONFFILEOUTDIR/database.inc
362 chown gforge:gforge $CONFFILEOUTDIR/local.pl $CONFFILEOUTDIR/database.inc
366 APACHECONF=/etc/apache/httpd.conf
367 GFORGE_ETC_SEARCH=$HTTPDCONF
368 export GFORGE_ETC_SEARCH
369 if [ -f $APACHECONF -a -f $BINDIR/install-apache.sh ] ; then
370 if [ ! -f /etc/apache/conf.d/gforge.httpd.conf ] ; then
371 if ! grep -q "^Include $GFORGE_ETC_SEARCH" $APACHECONF ; then
372 $BINDIR/install-apache.sh setup
374 echo "Found Include $GFORGE_ETC_SEARCH in $APACHECONF"
377 LINK=`ls -l /etc/apache/conf.d/gforge.httpd.conf | sed 's/.*-> \(.*\)$/\1/'`
378 if [ "$LINK" != "$GFORGE_ETC_SEARCH" ] ; then
379 echo Need to readjust Symlink
380 $BINDIR/install-apache.sh setup
382 if ! grep -q "^Include $GFORGE_ETC_SEARCH" $APACHECONF ; then
383 echo "Found /etc/apache/conf.d/gforge.httpd.conf"
385 # There is a link and an include
386 $BINDIR/install-apache.sh setup
394 ETCTEMPLATEDIR=`pwd`/etc
400 GROUPPATH=/home/groups
402 if [ ! -e /cvsroot ] && [ -e /var/lib/gforge/chroot/cvsroot ] ; then
403 CVSPATH=/var/lib/gforge/chroot/cvsroot
406 if [ ! -e /svnroot ] && [ -e /var/lib/gforge/chroot/svnroot ] ; then
407 SVNPATH=/var/lib/gforge/chroot/svnroot
411 CONFFILEOUTDIR=$ETCDIR
412 CONFFILEIN=$ETCDIR/gforge.conf
413 CONFFILEOUT=$ETCDIR/gforge.conf
414 LOCALINC=$ETCDIR/local.inc
415 HTTPDCONF=$ETCDIR/httpd.conf
416 HTTPDSECRETS=$ETCDIR/httpd.secrets
418 export ETCDIR ETCTEMPLATEDIR BINDIR GFGDIR CONFFILEOUTDIR CONFFILEIN CONFFILEOUT LOCALINC HTTPDCONF HTTPDSECRETS DOAPACHE SYSTEM
464 CONFFILEIN=$1/gforge.conf
465 CONFFILEOUT=$1/gforge.conf
466 LOCALINC=$1/local.inc
467 HTTPDCONF=$1/httpd.conf
468 HTTPDSECRETS=$1/httpd.secrets
469 echo Using $1 as config directory
474 ETCTEMPLATEDIR=/usr/share/gforge/etc
475 BINDIR=/usr/share/gforge/bin
476 CGIDIR=/usr/share/gforge/cgi-bin
479 GROUPPATH=/home/groups
480 CHROOT=/var/lib/gforge/chroot
481 SHAREDIR=/usr/share/gforge
482 LIBDIR=/usr/share/gforge
483 CONFFILEOUTDIR=/etc/gforge
484 CONFFILEIN=/etc/gforge/gforge.conf
485 CONFFILEOUT=/etc/gforge/gforge.conf
486 LOCALINC=/etc/gforge/local.inc
487 HTTPDCONF=/etc/gforge/httpd.conf
488 HTTPDSECRETS=/etc/gforge/httpd.secrets
513 CONFFILEIN=$ETCDIR/gforge.conf.example
514 CONFFILEOUT=$ETCDIR/gforge.conf.example
515 LOCALINC=$ETCDIR/local.inc.example
516 HTTPDCONF=$ETCDIR/httpd.conf.example
517 HTTPDSECRETS=$ETCDIR/httpd.secrets.example
530 [ -f $CONFFILEIN ] && echo Removing $CONFFILEIN && rm -f $CONFFILEIN
531 [ -f $CONFFILEOUT ] && echo Removing $CONFFILEOUT && rm -f $CONFFILEOUT
532 [ -f $LOCALINC ] && echo Removing $LOCALINC && rm -f $LOCALINC
533 [ -f $HTTPDCONF ] && echo Removing $HTTPDCONF && rm -f $HTTPDCONF
534 [ -f $HTTPDSECRETS ] && echo Removing $HTTPDSECRETS && rm -f $HTTPDSECRETS
549 [ "$noapache" != true ] && doapache