1 # BEGIN BPS TAGGED BLOCK {{{
5 # This software is Copyright (c) 1996-2005 Best Practical Solutions, LLC
6 # <jesse@bestpractical.com>
8 # (Except where explicitly superseded by other copyright notices)
13 # This work is made available to you under the terms of Version 2 of
14 # the GNU General Public License. A copy of that license should have
15 # been provided with this software, but in any event can be snarfed
18 # This work is distributed in the hope that it will be useful, but
19 # WITHOUT ANY WARRANTY; without even the implied warranty of
20 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21 # General Public License for more details.
23 # You should have received a copy of the GNU General Public License
24 # along with this program; if not, write to the Free Software
25 # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
28 # CONTRIBUTION SUBMISSION POLICY:
30 # (The following paragraph is not intended to limit the rights granted
31 # to you to modify and distribute this software under the terms of
32 # the GNU General Public License and is only of importance to you if
33 # you choose to contribute your changes and enhancements to the
34 # community by submitting them to Best Practical Solutions, LLC.)
36 # By intentionally submitting any modifications, corrections or
37 # derivatives to this work, or any other work intended for use with
38 # Request Tracker, to Best Practical Solutions, LLC, you confirm that
39 # you are the copyright holder for those contributions and you grant
40 # Best Practical Solutions, LLC a nonexclusive, worldwide, irrevocable,
41 # royalty-free, perpetual, license to use, copy, create derivative
42 # works based on those contributions, and sublicense and distribute
43 # those contributions and any derivatives thereof.
45 # END BPS TAGGED BLOCK }}}
47 # DO NOT HAND-EDIT the file named 'Makefile'. This file is autogenerated.
48 # Have a look at "configure" and "Makefile.in" instead
54 CONFIG_FILE_PATH = @CONFIG_FILE_PATH@
55 CONFIG_FILE = $(CONFIG_FILE_PATH)/RT_Config.pm
56 SITE_CONFIG_FILE = $(CONFIG_FILE_PATH)/RT_SiteConfig.pm
59 RT_VERSION_MAJOR = @RT_VERSION_MAJOR@
60 RT_VERSION_MINOR = @RT_VERSION_MINOR@
61 RT_VERSION_PATCH = @RT_VERSION_PATCH@
63 RT_VERSION = $(RT_VERSION_MAJOR).$(RT_VERSION_MINOR).$(RT_VERSION_PATCH)
64 TAG = rt-$(RT_VERSION_MAJOR)-$(RT_VERSION_MINOR)-$(RT_VERSION_PATCH)
67 # This is the group that all of the installed files will be chgrp'ed to.
71 # User which should own rt binaries.
72 BIN_OWNER = @BIN_OWNER@
74 # User that should own all of RT's libraries, generally root.
75 LIBS_OWNER = @LIBS_OWNER@
77 # Group that should own all of RT's libraries, generally root.
78 LIBS_GROUP = @LIBS_GROUP@
81 WEB_GROUP = @WEB_GROUP@
84 APACHECTL = @APACHECTL@
86 # {{{ Files and directories
88 # DESTDIR allows you to specify that RT be installed somewhere other than
89 # where it will eventually reside
95 RT_ETC_PATH = @RT_ETC_PATH@
96 RT_BIN_PATH = @RT_BIN_PATH@
97 RT_SBIN_PATH = @RT_SBIN_PATH@
98 RT_LIB_PATH = @RT_LIB_PATH@
99 RT_MAN_PATH = @RT_MAN_PATH@
100 RT_VAR_PATH = @RT_VAR_PATH@
101 RT_DOC_PATH = @RT_DOC_PATH@
102 RT_LOCAL_PATH = @RT_LOCAL_PATH@
103 LOCAL_ETC_PATH = @LOCAL_ETC_PATH@
104 LOCAL_LIB_PATH = @LOCAL_LIB_PATH@
105 LOCAL_LEXICON_PATH = @LOCAL_LEXICON_PATH@
106 MASON_HTML_PATH = @MASON_HTML_PATH@
107 MASON_LOCAL_HTML_PATH = @MASON_LOCAL_HTML_PATH@
108 MASON_DATA_PATH = @MASON_DATA_PATH@
109 MASON_SESSION_PATH = @MASON_SESSION_PATH@
110 RT_LOG_PATH = @RT_LOG_PATH@
112 # RT_READABLE_DIR_MODE is the mode of directories that are generally meant
114 RT_READABLE_DIR_MODE = 0755
119 # {{{ all these define the places that RT's binaries should get installed
121 # RT_MODPERL_HANDLER is the mason handler script for mod_perl
122 RT_MODPERL_HANDLER = $(RT_BIN_PATH)/webmux.pl
123 # RT_STANDALONE_SERVER is a stand-alone HTTP server
124 RT_STANDALONE_SERVER = $(RT_BIN_PATH)/standalone_httpd
125 # RT_SPEEDYCGI_HANDLER is the mason handler script for SpeedyCGI
126 RT_SPEEDYCGI_HANDLER = $(RT_BIN_PATH)/mason_handler.scgi
127 # RT_FASTCGI_HANDLER is the mason handler script for FastCGI
128 RT_FASTCGI_HANDLER = $(RT_BIN_PATH)/mason_handler.fcgi
129 # RT_WIN32_FASTCGI_HANDLER is the mason handler script for FastCGI
130 RT_WIN32_FASTCGI_HANDLER = $(RT_BIN_PATH)/mason_handler.svc
132 RT_CLI_BIN = $(RT_BIN_PATH)/rt
134 RT_MAILGATE_BIN = $(RT_BIN_PATH)/rt-mailgate
136 RT_CRON_BIN = $(RT_BIN_PATH)/rt-crontool
141 BINARIES = $(DESTDIR)/$(RT_MODPERL_HANDLER) \
142 $(DESTDIR)/$(RT_MAILGATE_BIN) \
143 $(DESTDIR)/$(RT_CLI_BIN) \
144 $(DESTDIR)/$(RT_CRON_BIN) \
145 $(DESTDIR)/$(RT_STANDALONE_SERVER) \
146 $(DESTDIR)/$(RT_SPEEDYCGI_HANDLER) \
147 $(DESTDIR)/$(RT_FASTCGI_HANDLER) \
148 $(DESTDIR)/$(RT_WIN32_FASTCGI_HANDLER)
149 SYSTEM_BINARIES = $(DESTDIR)/$(RT_SBIN_PATH)/
156 # DB_TYPE defines what sort of database RT trys to talk to
157 # "mysql" is known to work.
158 # "Pg" is known to work
159 # "Informix" is known to work
163 # Set DBA to the name of a unix account with the proper permissions and
164 # environment to run your commandline SQL sbin
166 # Set DB_DBA to the name of a DB user with permission to create new databases
168 # For mysql, you probably want 'root'
169 # For Pg, you probably want 'postgres'
170 # For Oracle, you want 'system'
171 # For Informix, you want 'informix'
177 # If you're not running your database server on its default port,
178 # specifiy the port the database server is running on below.
179 # It's generally safe to leave this blank
187 # Set this to the canonical name of the interface RT will be talking to the
188 # database on. If you said that the RT_DB_HOST above was "localhost," this
189 # should be too. This value will be used to grant rt access to the database.
190 # If you want to access the RT database from multiple hosts, you'll need
191 # to grant those database rights by hand.
194 DB_RT_HOST = @DB_RT_HOST@
196 # set this to the name you want to give to the RT database in
197 # your database server. For Oracle, this should be the name of your sid
199 DB_DATABASE = @DB_DATABASE@
200 DB_RT_USER = @DB_RT_USER@
201 DB_RT_PASS = @DB_RT_PASS@
206 ####################################################################
211 @echo "Please read RT's readme before installing. Not doing so could"
212 @echo "be dangerous."
217 @echo "Congratulations. RT has been installed. "
220 @echo "You must now configure RT by editing $(SITE_CONFIG_FILE)."
222 @echo "(You will definitely need to set RT's database password in "
223 @echo "$(SITE_CONFIG_FILE) before continuing. Not doing so could be "
224 @echo "very dangerous. Note that you do not have to manually add a "
225 @echo "database user or set up a database for RT. These actions will be "
226 @echo "taken care of in the next step.)"
228 @echo "After that, you need to initialize RT's database by running"
229 @echo " 'make initialize-database'"
231 # @echo " or by executing "
232 # @echo " '$(RT_SBIN_PATH)/rt-setup-database --action init \ "
233 # @echo " --dba $(DB_DBA) --prompt-for-dba-password'"
238 @echo "Congratulations. RT has been upgraded. You should now check-over"
239 @echo "$(CONFIG_FILE) for any necessary site customization. Additionally,"
240 @echo "you should update RT's system database objects by running "
241 @echo " ls etc/upgrade"
243 @echo "For each item in that directory whose name is greater than"
244 @echo "your previously installed RT version, run:"
245 @echo " $(RT_SBIN_PATH)/rt-setup-database --dba $(DB_DBA) --prompt-for-dba-password --action schema --datadir etc/upgrade/<version>"
246 @echo " $(RT_SBIN_PATH)/rt-setup-database --dba $(DB_DBA) --prompt-for-dba-password --action acl --datadir etc/upgrade/<version>"
247 @echo " $(RT_SBIN_PATH)/rt-setup-database --dba $(DB_DBA) --prompt-for-dba-password --action insert --datadir etc/upgrade/<version>"
250 upgrade: config-install dirs files-install fixperms upgrade-instruct
252 upgrade-noclobber: config-install libs-install html-install bin-install local-install doc-install fixperms
257 $(PERL) ./sbin/rt-test-dependencies --verbose --with-$(DB_TYPE)
262 $(PERL) ./sbin/rt-test-dependencies --verbose --install --with-$(DB_TYPE)
268 # Make the libraries readable
269 chmod $(RT_READABLE_DIR_MODE) $(DESTDIR)/$(RT_PATH)
270 chown -R $(LIBS_OWNER) $(DESTDIR)/$(RT_LIB_PATH)
271 chgrp -R $(LIBS_GROUP) $(DESTDIR)/$(RT_LIB_PATH)
272 chmod -R u+rwX,go-w,go+rX $(DESTDIR)/$(RT_LIB_PATH)
275 chmod $(RT_READABLE_DIR_MODE) $(DESTDIR)/$(RT_BIN_PATH)
276 chmod $(RT_READABLE_DIR_MODE) $(DESTDIR)/$(RT_BIN_PATH)
278 chmod 0755 $(DESTDIR)/$(RT_ETC_PATH)
279 chmod 0500 $(DESTDIR)/$(RT_ETC_PATH)/*
281 #TODO: the config file should probably be able to have its
282 # owner set separately from the binaries.
283 chown -R $(BIN_OWNER) $(DESTDIR)/$(RT_ETC_PATH)
284 chgrp -R $(RTGROUP) $(DESTDIR)/$(RT_ETC_PATH)
286 chmod 0550 $(DESTDIR)/$(CONFIG_FILE)
287 chmod 0550 $(DESTDIR)/$(SITE_CONFIG_FILE)
289 # Make the interfaces executable
290 chown $(BIN_OWNER) $(BINARIES)
291 chgrp $(RTGROUP) $(BINARIES)
292 chmod 0755 $(BINARIES)
294 # Make the web ui readable by all.
295 chmod -R u+rwX,go-w,go+rX $(DESTDIR)/$(MASON_HTML_PATH) \
296 $(DESTDIR)/$(MASON_LOCAL_HTML_PATH) \
297 $(DESTDIR)/$(LOCAL_LEXICON_PATH)
298 chown -R $(LIBS_OWNER) $(DESTDIR)/$(MASON_HTML_PATH) \
299 $(DESTDIR)/$(MASON_LOCAL_HTML_PATH)
300 chgrp -R $(LIBS_GROUP) $(DESTDIR)/$(MASON_HTML_PATH) \
301 $(DESTDIR)/$(MASON_LOCAL_HTML_PATH)
303 # Make the web ui's data dir writable
304 chmod 0770 $(DESTDIR)/$(MASON_DATA_PATH) \
305 $(DESTDIR)/$(MASON_SESSION_PATH)
306 chown -R $(WEB_USER) $(DESTDIR)/$(MASON_DATA_PATH) \
307 $(DESTDIR)/$(MASON_SESSION_PATH)
308 chgrp -R $(WEB_GROUP) $(DESTDIR)/$(MASON_DATA_PATH) \
309 $(DESTDIR)/$(MASON_SESSION_PATH)
314 mkdir -p $(DESTDIR)/$(RT_LOG_PATH)
315 mkdir -p $(DESTDIR)/$(MASON_DATA_PATH)
316 mkdir -p $(DESTDIR)/$(MASON_DATA_PATH)/cache
317 mkdir -p $(DESTDIR)/$(MASON_DATA_PATH)/etc
318 mkdir -p $(DESTDIR)/$(MASON_DATA_PATH)/obj
319 mkdir -p $(DESTDIR)/$(MASON_SESSION_PATH)
320 mkdir -p $(DESTDIR)/$(MASON_HTML_PATH)
321 mkdir -p $(DESTDIR)/$(MASON_LOCAL_HTML_PATH)
322 mkdir -p $(DESTDIR)/$(LOCAL_ETC_PATH)
323 mkdir -p $(DESTDIR)/$(LOCAL_LIB_PATH)
324 mkdir -p $(DESTDIR)/$(LOCAL_LEXICON_PATH)
327 install: config-install dirs files-install fixperms instruct
329 files-install: libs-install etc-install bin-install sbin-install html-install local-install doc-install
332 mkdir -p $(DESTDIR)/$(CONFIG_FILE_PATH)
333 -cp etc/RT_Config.pm $(DESTDIR)/$(CONFIG_FILE)
334 [ -f $(DESTDIR)/$(SITE_CONFIG_FILE) ] || cp etc/RT_SiteConfig.pm $(DESTDIR)/$(SITE_CONFIG_FILE)
336 chgrp $(RTGROUP) $(DESTDIR)/$(CONFIG_FILE)
337 chown $(BIN_OWNER) $(DESTDIR)/$(CONFIG_FILE)
339 chgrp $(RTGROUP) $(DESTDIR)/$(SITE_CONFIG_FILE)
340 chown $(BIN_OWNER) $(DESTDIR)/$(SITE_CONFIG_FILE)
342 @echo "Installed configuration. about to install rt in $(RT_PATH)"
345 $(PERL) -Ilib lib/t/00smoke.t
347 regression-install: config-install
348 $(PERL) -pi -e 's/Set\(\$$DatabaseName.*\);/Set\(\$$DatabaseName, "rt3regression"\);/' $(DESTDIR)/$(CONFIG_FILE)
350 regression: regression-install dirs files-install libs-install sbin-install bin-install regression-instruct regression-reset-db testify-pods fixperms apachectl run-regression
353 prove -Ilib lib/t/setup_regression.t lib/t/autogen/ lib/t/regression/
356 regression-noapache: regression-install dirs files-install libs-install sbin-install bin-install regression-instruct regression-reset-db testify-pods fixperms start-httpd run-regression
359 $(PERL) sbin/regression_harness
362 @echo "About to wipe your database for a regression test. ABORT NOW with Control-C"
365 # {{{ database-installation
368 $(PERL) $(DESTDIR)/$(RT_SBIN_PATH)/rt-setup-database --action drop --dba $(DB_DBA) --dba-password '' --force
369 $(PERL) $(DESTDIR)/$(RT_SBIN_PATH)/rt-setup-database --action init --dba $(DB_DBA) --dba-password ''
371 initdb :: initialize-database
374 $(PERL) $(DESTDIR)/$(RT_SBIN_PATH)/rt-setup-database --action init --dba $(DB_DBA) --prompt-for-dba-password
377 $(PERL) $(DESTDIR)/$(RT_SBIN_PATH)/rt-setup-database --action drop --dba $(DB_DBA) --prompt-for-dba-password
379 insert-approval-data:
380 $(PERL) $(DESTDIR)/$(RT_SBIN_PATH)/insert_approval_scrips
385 [ -d $(DESTDIR)/$(RT_LIB_PATH) ] || mkdir -p $(DESTDIR)/$(RT_LIB_PATH)
386 -cp -rp lib/* $(DESTDIR)/$(RT_LIB_PATH)
391 [ -d $(DESTDIR)/$(MASON_HTML_PATH) ] || mkdir -p $(DESTDIR)/$(MASON_HTML_PATH)
392 -cp -rp ./html/* $(DESTDIR)/$(MASON_HTML_PATH)
397 # RT 3.0.0 - RT 3.0.2 would accidentally create a file instead of a dir
398 -[ -f $(DESTDIR)/$(RT_DOC_PATH) ] && rm $(DESTDIR)/$(RT_DOC_PATH)
399 [ -d $(DESTDIR)/$(RT_DOC_PATH) ] || mkdir -p $(DESTDIR)/$(RT_DOC_PATH)
400 -cp -rp ./README $(DESTDIR)/$(RT_DOC_PATH)
406 mkdir -p $(DESTDIR)/$(RT_ETC_PATH)
411 $(DESTDIR)/$(RT_ETC_PATH)
417 mkdir -p $(DESTDIR)/$(RT_SBIN_PATH)
419 sbin/rt-dump-database \
420 sbin/rt-setup-database \
421 sbin/rt-test-dependencies
423 sbin/rt-dump-database \
424 sbin/rt-setup-database \
425 sbin/rt-test-dependencies \
426 $(DESTDIR)/$(RT_SBIN_PATH)
433 mkdir -p $(DESTDIR)/$(RT_BIN_PATH)
434 chmod +x bin/rt-mailgate \
438 bin/mason_handler.fcgi \
439 bin/mason_handler.scgi \
440 bin/standalone_httpd \
441 bin/mason_handler.svc \
445 $(DESTDIR)/$(RT_BIN_PATH)
450 -cp -rp ./local/html/* $(DESTDIR)/$(MASON_LOCAL_HTML_PATH)
451 -cp -rp ./local/po/* $(DESTDIR)/$(LOCAL_LEXICON_PATH)
452 -cp -rp ./local/etc/* $(DESTDIR)/$(LOCAL_ETC_PATH)
455 # {{{ Best Practical Build targets -- no user servicable parts inside
458 POD2TEST_EXE = sbin/extract_pod_tests
461 [ -d lib/t/autogen ] || mkdir lib/t/autogen
462 find lib -name \*pm |grep -v .svn | grep -v \*.in |xargs -n 1 $(PERL) $(POD2TEST_EXE)
463 find bin -type f |grep -v .svn | grep -v \~ | grep -v "\.in" | xargs -n 1 $(PERL) $(POD2TEST_EXE)
464 find lib -name \*pm |grep -v .svn | grep -v \*.in |xargs -n 1 $(PERL) $(POD2TEST_EXE)
465 find bin -type f |grep -v .svn | grep -v \~ | grep -v "\.in" | xargs -n 1 $(PERL) $(POD2TEST_EXE)
470 $(PERL) sbin/extract-message-catalog
473 $(PERL) sbin/license_tag
475 factory: initialize-database
476 cd lib; $(PERL) ../sbin/factory $(DB_DATABASE) RT
481 chmod 755 ./configure
485 $(PERL) bin/standalone_httpd 80 &