combine ticket notification scrips, #15353
[freeside.git] / rt / Makefile.in
index 13f3db4..f963faa 100644 (file)
@@ -1,45 +1,72 @@
-# BEGIN LICENSE BLOCK
-# 
-# Copyright (c) 1996-2003 Jesse Vincent <jesse@bestpractical.com>
-# 
-# (Except where explictly superceded by other copyright notices)
-# 
+# BEGIN BPS TAGGED BLOCK {{{
+#
+# COPYRIGHT:
+#
+# This software is Copyright (c) 1996-2011 Best Practical Solutions, LLC
+#                                          <sales@bestpractical.com>
+#
+# (Except where explicitly superseded by other copyright notices)
+#
+#
+# LICENSE:
+#
 # This work is made available to you under the terms of Version 2 of
 # the GNU General Public License. A copy of that license should have
 # been provided with this software, but in any event can be snarfed
 # from www.gnu.org.
-# 
+#
 # This work is distributed in the hope that it will be useful, but
 # WITHOUT ANY WARRANTY; without even the implied warranty of
 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 # General Public License for more details.
-# 
-# Unless otherwise specified, all modifications, corrections or
-# extensions to this work which alter its source code become the
-# property of Best Practical Solutions, LLC when submitted for
-# inclusion in the work.
-# 
-# 
-# END LICENSE BLOCK
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+# 02110-1301 or visit their web page on the internet at
+# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html.
+#
+#
+# CONTRIBUTION SUBMISSION POLICY:
+#
+# (The following paragraph is not intended to limit the rights granted
+# to you to modify and distribute this software under the terms of
+# the GNU General Public License and is only of importance to you if
+# you choose to contribute your changes and enhancements to the
+# community by submitting them to Best Practical Solutions, LLC.)
+#
+# By intentionally submitting any modifications, corrections or
+# derivatives to this work, or any other work intended for use with
+# Request Tracker, to Best Practical Solutions, LLC, you confirm that
+# you are the copyright holder for those contributions and you grant
+# Best Practical Solutions,  LLC a nonexclusive, worldwide, irrevocable,
+# royalty-free, perpetual, license to use, copy, create derivative
+# works based on those contributions, and sublicense and distribute
+# those contributions and any derivatives thereof.
+#
+# END BPS TAGGED BLOCK }}}
 #
 # DO NOT HAND-EDIT the file named 'Makefile'. This file is autogenerated.
 # Have a look at "configure" and "Makefile.in" instead
 #
 
 
-PERL                   =       @PERL@
+PERL                   =       @PERL@
+INSTALL                        =       @INSTALL@
+
+RT_LAYOUT              =       @rt_layout_name@
 
-CONFIG_FILE_PATH       =       @CONFIG_FILE_PATH@
-CONFIG_FILE            =       $(CONFIG_FILE_PATH)/RT_Config.pm
-SITE_CONFIG_FILE               =       $(CONFIG_FILE_PATH)/RT_SiteConfig.pm
+CONFIG_FILE_PATH       =       @CONFIG_FILE_PATH_R@
+CONFIG_FILE            =       $(CONFIG_FILE_PATH)/RT_Config.pm
+SITE_CONFIG_FILE       =       $(CONFIG_FILE_PATH)/RT_SiteConfig.pm
 
 
 RT_VERSION_MAJOR       =       @RT_VERSION_MAJOR@
 RT_VERSION_MINOR       =       @RT_VERSION_MINOR@
 RT_VERSION_PATCH       =       @RT_VERSION_PATCH@
 
-RT_VERSION =   $(RT_VERSION_MAJOR).$(RT_VERSION_MINOR).$(RT_VERSION_PATCH)
-TAG       =    rt-$(RT_VERSION_MAJOR)-$(RT_VERSION_MINOR)-$(RT_VERSION_PATCH)
+RT_VERSION             =       $(RT_VERSION_MAJOR).$(RT_VERSION_MINOR).$(RT_VERSION_PATCH)
+TAG                    =       rt-$(RT_VERSION_MAJOR)-$(RT_VERSION_MINOR)-$(RT_VERSION_PATCH)
 
 
 # This is the group that all of the installed files will be chgrp'ed to.
@@ -58,31 +85,38 @@ LIBS_GROUP          =       @LIBS_GROUP@
 WEB_USER               =       @WEB_USER@
 WEB_GROUP              =       @WEB_GROUP@
 
+
+APACHECTL              =       @APACHECTL@
+
 # {{{ Files and directories 
 
 # DESTDIR allows you to specify that RT be installed somewhere other than
-# where it will eventually reside
+# where it will eventually reside. DESTDIR _must_ have a trailing slash
+# if it's defined.
 
 DESTDIR                        =       
 
 
-RT_PATH                        =       @RT_PATH@
-RT_ETC_PATH            =       @RT_ETC_PATH@
-RT_BIN_PATH            =       @RT_BIN_PATH@
-RT_SBIN_PATH           =       @RT_SBIN_PATH@
-RT_LIB_PATH            =       @RT_LIB_PATH@
-RT_MAN_PATH            =       @RT_MAN_PATH@
-RT_VAR_PATH            =       @RT_VAR_PATH@
-RT_DOC_PATH            =       @RT_DOC_PATH@
-RT_LOCAL_PATH          =       @RT_LOCAL_PATH@
-LOCAL_ETC_PATH         =       @LOCAL_ETC_PATH@
-LOCAL_LIB_PATH         =       @LOCAL_LIB_PATH@
-LOCAL_LEXICON_PATH     =       @LOCAL_LEXICON_PATH@
-MASON_HTML_PATH                =       @MASON_HTML_PATH@
-MASON_LOCAL_HTML_PATH  =       @MASON_LOCAL_HTML_PATH@
-MASON_DATA_PATH                =       @MASON_DATA_PATH@
-MASON_SESSION_PATH     =       @MASON_SESSION_PATH@
-RT_LOG_PATH        =       @RT_LOG_PATH@
+
+RT_PATH                        =       @RT_PATH_R@
+RT_ETC_PATH            =       @RT_ETC_PATH_R@
+RT_BIN_PATH            =       @RT_BIN_PATH_R@
+RT_SBIN_PATH           =       @RT_SBIN_PATH_R@
+RT_LIB_PATH            =       @RT_LIB_PATH_R@
+RT_MAN_PATH            =       @RT_MAN_PATH_R@
+RT_VAR_PATH            =       @RT_VAR_PATH_R@
+RT_DOC_PATH            =       @RT_DOC_PATH_R@
+RT_FONT_PATH           =       @RT_FONT_PATH_R@
+RT_LOCAL_PATH          =       @RT_LOCAL_PATH_R@
+LOCAL_PLUGIN_PATH      =       @RT_LOCAL_PATH_R@/plugins
+LOCAL_ETC_PATH         =       @LOCAL_ETC_PATH_R@
+LOCAL_LIB_PATH         =       @LOCAL_LIB_PATH_R@
+LOCAL_LEXICON_PATH     =       @LOCAL_LEXICON_PATH_R@
+MASON_HTML_PATH                =       @MASON_HTML_PATH_R@
+MASON_LOCAL_HTML_PATH  =       @MASON_LOCAL_HTML_PATH_R@
+MASON_DATA_PATH                =       @MASON_DATA_PATH_R@
+MASON_SESSION_PATH     =       @MASON_SESSION_PATH_R@
+RT_LOG_PATH            =       @RT_LOG_PATH_R@
 
 # RT_READABLE_DIR_MODE is the mode of directories that are generally meant
 # to be accessable
@@ -94,29 +128,74 @@ RT_READABLE_DIR_MODE       =       0755
 # {{{ all these define the places that RT's binaries should get installed
 
 # RT_MODPERL_HANDLER is the mason handler script for mod_perl
-RT_MODPERL_HANDLER     =       $(RT_BIN_PATH)/webmux.pl
+RT_MODPERL_HANDLER     =       webmux.pl
+# RT_STANDALONE_SERVER is a stand-alone HTTP server
+RT_STANDALONE_SERVER   =       standalone_httpd
+# RT_SPEEDYCGI_HANDLER is the mason handler script for SpeedyCGI
+RT_SPEEDYCGI_HANDLER   =       mason_handler.scgi
 # RT_FASTCGI_HANDLER is the mason handler script for FastCGI
-RT_FASTCGI_HANDLER     =       $(RT_BIN_PATH)/mason_handler.fcgi
+RT_FASTCGI_HANDLER     =       mason_handler.fcgi
+# RT_FASTCGI_SERVER is the FastCGI server
+RT_FASTCGI_SERVER      =       fastcgi_server
 # RT_WIN32_FASTCGI_HANDLER is the mason handler script for FastCGI
-RT_WIN32_FASTCGI_HANDLER       =       $(RT_BIN_PATH)/mason_handler.svc
+RT_WIN32_FASTCGI_HANDLER       =       mason_handler.svc
 # RT's CLI
-RT_CLI_BIN             =       $(RT_BIN_PATH)/rt
+RT_CLI_BIN             =       rt
 # RT's mail gateway
-RT_MAILGATE_BIN                =       $(RT_BIN_PATH)/rt-mailgate
+RT_MAILGATE_BIN                =       rt-mailgate
 # RT's cron tool
-RT_CRON_BIN            =       $(RT_BIN_PATH)/rt-crontool
+RT_CRON_BIN            =       rt-crontool
 
 # }}}
 
-SETGID_BINARIES                =       $(DESTDIR)/$(RT_FASTCGI_HANDLER) \
-                               $(DESTDIR)/$(RT_WIN32_FASTCGI_HANDLER)
 
-BINARIES               =       $(DESTDIR)/$(RT_MODPERL_HANDLER) \
-                               $(DESTDIR)/$(RT_MAILGATE_BIN) \
-                               $(DESTDIR)/$(RT_CLI_BIN) \
-                               $(DESTDIR)/$(RT_CRON_BIN) \
-                               $(SETGID_BINARIES)
-SYSTEM_BINARIES                =       $(DESTDIR)/$(RT_SBIN_PATH)/
+BINARIES               =       $(RT_MODPERL_HANDLER) \
+                               $(RT_MAILGATE_BIN) \
+                               $(RT_CLI_BIN) \
+                               $(RT_CRON_BIN) \
+                               $(RT_STANDALONE_SERVER) \
+                               $(RT_SPEEDYCGI_HANDLER) \
+                               $(RT_FASTCGI_HANDLER) \
+                               $(RT_FASTCGI_SERVER) \
+                               $(RT_WIN32_FASTCGI_HANDLER)
+
+
+
+
+
+SYSTEM_BINARIES                =       rt-attributes-viewer \
+                               rt-dump-database \
+                               rt-setup-database \
+                               rt-email-digest \
+                               rt-email-dashboards \
+                               rt-email-group-admin \
+                               rt-server \
+                               rt-session-viewer \
+                               rt-test-dependencies \
+                               rt-clean-sessions \
+                               rt-shredder \
+                               rt-validator
+
+
+ETC_FILES              =       acl.Informix \
+                               acl.Pg \
+                               acl.Oracle \
+                               acl.mysql \
+                               acl.Sybase \
+                               schema.Informix \
+                               schema.Pg \
+                               schema.Oracle \
+                               schema.mysql-4.0 \
+                               schema.mysql-4.1 \
+                               schema.Sybase \
+                               schema.SQLite \
+                               initialdata
+
+# }}}
+
+# {{{ Web frontend
+
+WEB_HANDLER            =       @WEB_HANDLER@
 
 # }}}
 
@@ -173,261 +252,253 @@ DB_RT_PASS              =       @DB_RT_PASS@
 # }}}
 
 
+TEST_FILES = t/*.t t/*/*.t
+TEST_VERBOSE = 0
+
+
 ####################################################################
 
 all: default
 
 default:
-       @echo "Please read RT's readme before installing. Not doing so could"
-       @echo "be dangerous."
+       @echo "Please read RT's README before beginning your installation."
 
 
 
 instruct:
-       @echo "Congratulations. RT has been installed. "
+       @echo "Congratulations. RT is now installed."
        @echo ""
        @echo ""
        @echo "You must now configure RT by editing $(SITE_CONFIG_FILE)."
        @echo ""
-       @echo "(You will definitely need to set RT's database password before continuing."
-       @echo " Not doing so could be very dangerous)"
+       @echo "(You will definitely need to set RT's database password in "
+       @echo "$(SITE_CONFIG_FILE) before continuing. Not doing so could be "
+       @echo "very dangerous.  Note that you do not have to manually add a "
+       @echo "database user or set up a database for RT.  These actions will be "
+       @echo "taken care of in the next step.)"
        @echo ""
        @echo "After that, you need to initialize RT's database by running" 
        @echo " 'make initialize-database'"
 
-#      @echo " or by executing "       
-#      @echo " '$(RT_SBIN_PATH)/rt-setup-database --action init \ "
-#      @echo "     --dba $(DB_DBA) --prompt-for-dba-password'"
-
-
 
 upgrade-instruct: 
-       @echo "Congratulations. RT has been upgraded. You should now check-over"
+       @echo "Congratulations. RT has been upgraded. You should now check over"
        @echo "$(CONFIG_FILE) for any necessary site customization. Additionally,"
        @echo "you should update RT's system database objects by running "
-       @echo "   ls etc/upgrade"
-       @echo "For each file in that directory whose name is greater than"
-       @echo "your previously installed RT version, run:"
-       @echo "    $(RT_SBIN_PATH)/rt-setup-database --action insert --datafile etc/upgrade/<version>"
+       @echo "    $(RT_SBIN_PATH)/rt-setup-database --dba $(DB_DBA) --prompt-for-dba-password --action upgrade"
 
 
-upgrade: config-install dirs files-install fixperms upgrade-instruct
+upgrade: testdeps config-install dirs files-install fixperms upgrade-instruct
 
-upgrade-noclobber: config-install libs-install html-install bin-install local-install doc-install fixperms
+upgrade-noclobber: config-install dirs libs-install html-install bin-install local-install doc-install font-install fixperms
 
 
 # {{{ dependencies
+
+my_with_web_handlers= $(shell $(PERL) -e 'print join " ", map "--with-$$_", grep defined && length, split /,/, "$(WEB_HANDLER)"')
 testdeps:
-       $(PERL) ./sbin/rt-test-dependencies --with-$(DB_TYPE)
+       $(PERL) ./sbin/rt-test-dependencies --verbose --with-$(DB_TYPE) $(my_with_web_handlers)
+
+depends: fixdeps
 
 fixdeps:
-       $(PERL) ./sbin/rt-test-dependencies --install --with-$(DB_TYPE)
+       $(PERL) ./sbin/rt-test-dependencies --verbose --install --with-$(DB_TYPE) $(my_with_web_handlers)
 
 #}}}
 
 # {{{ fixperms
 fixperms:
        # Make the libraries readable
-       chmod $(RT_READABLE_DIR_MODE) $(DESTDIR)/$(RT_PATH)
-       chown -R $(LIBS_OWNER) $(DESTDIR)/$(RT_LIB_PATH)
-       chgrp -R $(LIBS_GROUP) $(DESTDIR)/$(RT_LIB_PATH)
-       chmod -R  u+rwX,go-w,go+rX      $(DESTDIR)/$(RT_LIB_PATH)
+       chmod $(RT_READABLE_DIR_MODE) $(DESTDIR)$(RT_PATH)
+       chown -R $(LIBS_OWNER) $(DESTDIR)$(RT_LIB_PATH)
+       chgrp -R $(LIBS_GROUP) $(DESTDIR)$(RT_LIB_PATH)
+       chmod -R  u+rwX,go-w,go+rX $(DESTDIR)$(RT_LIB_PATH)
 
 
-       chmod $(RT_READABLE_DIR_MODE) $(DESTDIR)/$(RT_BIN_PATH)
-       chmod $(RT_READABLE_DIR_MODE) $(DESTDIR)/$(RT_BIN_PATH) 
+       chmod $(RT_READABLE_DIR_MODE) $(DESTDIR)$(RT_BIN_PATH)
 
-       chmod 0755 $(DESTDIR)/$(RT_ETC_PATH)
-       chmod 0500 $(DESTDIR)/$(RT_ETC_PATH)/*
+       chmod 0755 $(DESTDIR)$(RT_ETC_PATH)
+       cd $(DESTDIR)$(RT_ETC_PATH) && chmod 0400 $(ETC_FILES) || true
 
        #TODO: the config file should probably be able to have its
-       # owner set seperately from the binaries.
-       chown -R $(BIN_OWNER) $(DESTDIR)/$(RT_ETC_PATH)
-       chgrp -R $(RTGROUP) $(DESTDIR)/$(RT_ETC_PATH)
+       # owner set separately from the binaries.
+       chown -R $(BIN_OWNER) $(DESTDIR)$(RT_ETC_PATH)
+       chgrp -R $(RTGROUP) $(DESTDIR)$(RT_ETC_PATH)
+
+       chmod 0440 $(DESTDIR)$(CONFIG_FILE)
+       chmod 0640 $(DESTDIR)$(SITE_CONFIG_FILE)
+       # Make this externally readable
+       chmod 0440 $(DESTDIR)$(RT_ETC_PATH)/initialdata
 
-       chmod 0550 $(DESTDIR)/$(CONFIG_FILE)
-       chmod 0550 $(DESTDIR)/$(SITE_CONFIG_FILE)
+       # Make the system binaries
+       cd $(DESTDIR)$(RT_BIN_PATH) && ( chmod 0755 $(BINARIES) ; chown $(BIN_OWNER) $(BINARIES);  chgrp $(RTGROUP) $(BINARIES))
 
-       # Make the interfaces executable and setgid rt
-       chown $(BIN_OWNER) $(BINARIES)
-       chgrp $(RTGROUP) $(BINARIES)
-       chmod 0755  $(BINARIES)
-       chmod g+s $(SETGID_BINARIES)
+       # Make the system binaries executable also
+       cd $(DESTDIR)$(RT_SBIN_PATH) && ( chmod 0755 $(SYSTEM_BINARIES) ; chown $(BIN_OWNER) $(SYSTEM_BINARIES);  chgrp $(RTGROUP) $(SYSTEM_BINARIES))
 
        # Make the web ui readable by all. 
-       chmod -R  u+rwX,go-w,go+rX      $(DESTDIR)/$(MASON_HTML_PATH) \
-                                       $(DESTDIR)/$(MASON_LOCAL_HTML_PATH) \
-                                       $(DESTDIR)/$(LOCAL_LEXICON_PATH)
-       chown -R $(LIBS_OWNER)  $(DESTDIR)/$(MASON_HTML_PATH) \
-                               $(DESTDIR)/$(MASON_LOCAL_HTML_PATH)
-       chgrp -R $(LIBS_GROUP)  $(DESTDIR)/$(MASON_HTML_PATH) \
-                               $(DESTDIR)/$(MASON_LOCAL_HTML_PATH)
+       chmod -R  u+rwX,go-w,go+rX      $(DESTDIR)$(MASON_HTML_PATH) \
+                                       $(DESTDIR)$(MASON_LOCAL_HTML_PATH) \
+                                       $(DESTDIR)$(LOCAL_LEXICON_PATH)
+       chown -R $(LIBS_OWNER)  $(DESTDIR)$(MASON_HTML_PATH) \
+                               $(DESTDIR)$(MASON_LOCAL_HTML_PATH)
+       chgrp -R $(LIBS_GROUP)  $(DESTDIR)$(MASON_HTML_PATH) \
+                               $(DESTDIR)$(MASON_LOCAL_HTML_PATH)
 
        # Make the web ui's data dir writable
-       chmod 0770      $(DESTDIR)/$(MASON_DATA_PATH) \
-                       $(DESTDIR)/$(MASON_SESSION_PATH)
-       chown -R $(WEB_USER)    $(DESTDIR)/$(MASON_DATA_PATH) \
-                               $(DESTDIR)/$(MASON_SESSION_PATH)
-       chgrp -R $(WEB_GROUP)   $(DESTDIR)/$(MASON_DATA_PATH) \
-                               $(DESTDIR)/$(MASON_SESSION_PATH)
+       chmod 0770      $(DESTDIR)$(MASON_DATA_PATH) \
+                       $(DESTDIR)$(MASON_SESSION_PATH)
+       chown -R $(WEB_USER)    $(DESTDIR)$(MASON_DATA_PATH) \
+                               $(DESTDIR)$(MASON_SESSION_PATH)
+       chgrp -R $(WEB_GROUP)   $(DESTDIR)$(MASON_DATA_PATH) \
+                               $(DESTDIR)$(MASON_SESSION_PATH)
 # }}}
 
-fixperms-nosetgid: fixperms
-       @echo "You should never be running RT this way. it's unsafe"
-       chmod 0555 $(SETGID_BINARIES)
-       chmod 0555 $(DESTDIR)/$(CONFIG_FILE)
-       chmod 0555 $(DESTDIR)/$(SITE_CONFIG_FILE)
-
 # {{{ dirs
 dirs:
-       mkdir -p $(DESTDIR)/$(RT_LOG_PATH)
-       mkdir -p $(DESTDIR)/$(MASON_DATA_PATH)
-       mkdir -p $(DESTDIR)/$(MASON_DATA_PATH)/cache
-       mkdir -p $(DESTDIR)/$(MASON_DATA_PATH)/etc
-       mkdir -p $(DESTDIR)/$(MASON_DATA_PATH)/obj
-       mkdir -p $(DESTDIR)/$(MASON_SESSION_PATH)
-       mkdir -p $(DESTDIR)/$(MASON_HTML_PATH)
-       mkdir -p $(DESTDIR)/$(MASON_LOCAL_HTML_PATH)
-       mkdir -p $(DESTDIR)/$(LOCAL_ETC_PATH)
-       mkdir -p $(DESTDIR)/$(LOCAL_LIB_PATH)
-       mkdir -p $(DESTDIR)/$(LOCAL_LEXICON_PATH)
+       $(INSTALL) -m 0755 -d $(DESTDIR)$(RT_LOG_PATH)
+       $(INSTALL) -m 0755 -d $(DESTDIR)$(RT_FONT_PATH)
+       $(INSTALL) -m 0770 -d $(DESTDIR)$(MASON_DATA_PATH)
+       $(INSTALL) -m 0770 -d $(DESTDIR)$(MASON_DATA_PATH)/cache
+       $(INSTALL) -m 0770 -d $(DESTDIR)$(MASON_DATA_PATH)/etc
+       $(INSTALL) -m 0770 -d $(DESTDIR)$(MASON_DATA_PATH)/obj
+       $(INSTALL) -m 0770 -d $(DESTDIR)$(MASON_SESSION_PATH)
+       $(INSTALL) -m 0755 -d $(DESTDIR)$(MASON_HTML_PATH)
+       $(INSTALL) -m 0755 -d $(DESTDIR)$(MASON_LOCAL_HTML_PATH)
+       $(INSTALL) -m 0755 -d $(DESTDIR)$(LOCAL_ETC_PATH)
+       $(INSTALL) -m 0755 -d $(DESTDIR)$(LOCAL_LIB_PATH)
+       $(INSTALL) -m 0755 -d $(DESTDIR)$(LOCAL_PLUGIN_PATH)
+       $(INSTALL) -m 0755 -d $(DESTDIR)$(LOCAL_LEXICON_PATH)
 # }}}
 
-install: config-install dirs files-install fixperms instruct
+install: testdeps config-install dirs files-install fixperms instruct
 
-files-install: libs-install etc-install bin-install sbin-install html-install local-install doc-install
+files-install: libs-install etc-install config-install bin-install sbin-install html-install local-install doc-install font-install
 
 config-install:
-       mkdir -p $(DESTDIR)/$(CONFIG_FILE_PATH) 
-       cp etc/RT_Config.pm $(DESTDIR)/$(CONFIG_FILE)
-       [ -f $(DESTDIR)/$(SITE_CONFIG_FILE) ] || cp etc/RT_SiteConfig.pm $(DESTDIR)/$(SITE_CONFIG_FILE) 
-
-       chgrp $(RTGROUP) $(DESTDIR)/$(CONFIG_FILE)
-       chown $(BIN_OWNER) $(DESTDIR)/$(CONFIG_FILE)
-
-       chgrp $(RTGROUP) $(DESTDIR)/$(SITE_CONFIG_FILE)
-       chown $(BIN_OWNER) $(DESTDIR)/$(SITE_CONFIG_FILE)
-
-       @echo "Installed configuration. about to install rt in  $(RT_PATH)"
+@COMMENT_INPLACE_LAYOUT@       $(INSTALL) -m 0755 -o $(BIN_OWNER) -g $(RTGROUP) -d $(DESTDIR)$(CONFIG_FILE_PATH)
+@COMMENT_INPLACE_LAYOUT@       -$(INSTALL) -m 0440 -o $(BIN_OWNER) -g $(RTGROUP)  etc/RT_Config.pm $(DESTDIR)$(CONFIG_FILE)
+@COMMENT_INPLACE_LAYOUT@       [ -f $(DESTDIR)$(SITE_CONFIG_FILE) ] || $(INSTALL) -m 0640 -o $(BIN_OWNER) -g $(RTGROUP) etc/RT_SiteConfig.pm $(DESTDIR)$(SITE_CONFIG_FILE) 
+@COMMENT_INPLACE_LAYOUT@       @echo "Installed configuration. About to install RT in  $(RT_PATH)"
 
 test: 
-       $(PERL) -Ilib lib/t/00smoke.t
-
-regression-install: config-install
-       $(PERL) -pi -e 's/Set\(\$$DatabaseName.*\);/Set\(\$$DatabaseName, "rt3regression"\);/' $(DESTDIR)/$(CONFIG_FILE)
-
-regression-nosetgid-quiet: regression-install dirs files-install libs-install sbin-install bin-install regression-instruct regression-reset-db  testify-pods fixperms-nosetgid apachectl
-       $(PERL) sbin/regression_harness
-
-regression-nosetgid: regression-install dirs files-install libs-install sbin-install bin-install regression-instruct regression-reset-db  testify-pods fixperms-nosetgid apachectl
-       $(PERL) lib/t/02regression.t
-
-regression: regression-install dirs files-install libs-install sbin-install bin-install regression-instruct regression-reset-db  testify-pods fixperms apachectl
-       $(PERL) lib/t/02regression.t
+       $(PERL) "-MExtUtils::Command::MM" -e "test_harness($(TEST_VERBOSE), 'lib')" $(TEST_FILES)
 
-regression-quiet:
-       $(PERL) sbin/regression_harness
+parallel-test: test-parallel
 
-regression-instruct:
-       @echo "About to wipe your database for a regression test. ABORT NOW with Control-C"
+test-parallel: 
+       RT_TEST_PARALLEL=1 HARNESS_OPTIONS="j4" $(PERL) "-MExtUtils::Command::MM" -e "test_harness($(TEST_VERBOSE), 'lib')" $(TEST_FILES)
 
+regression-install: config-install
+       $(PERL) -pi -e 's/Set\(\$$DatabaseName.*\);/Set\(\$$DatabaseName, "rt3regression"\);/' $(DESTDIR)$(CONFIG_FILE)
 
 # {{{ database-installation
 
-regression-reset-db:
-       $(PERL) $(DESTDIR)/$(RT_SBIN_PATH)/rt-setup-database --action drop --dba $(DB_DBA) --dba-password ''
-       $(PERL) $(DESTDIR)/$(RT_SBIN_PATH)/rt-setup-database --action init --dba $(DB_DBA) --dba-password ''
+regression-reset-db: force-dropdb
+       $(PERL) -I$(LOCAL_LIB_PATH) -I$(RT_LIB_PATH) sbin/rt-setup-database --action init --dba $(DB_DBA) --dba-password ''
+
+initdb :: initialize-database
 
 initialize-database: 
-       $(PERL) $(DESTDIR)/$(RT_SBIN_PATH)/rt-setup-database --action init --dba $(DB_DBA) --prompt-for-dba-password
+       $(PERL) -I$(LOCAL_LIB_PATH) -I$(RT_LIB_PATH) sbin/rt-setup-database --action init --dba $(DB_DBA) --prompt-for-dba-password
 
 dropdb: 
-       $(PERL) $(DESTDIR)/$(RT_SBIN_PATH)/rt-setup-database --action drop --dba $(DB_DBA) --prompt-for-dba-password
+       $(PERL) -I$(LOCAL_LIB_PATH) -I$(RT_LIB_PATH) sbin/rt-setup-database --action drop --dba $(DB_DBA) --prompt-for-dba-password
+
+force-dropdb: 
+       $(PERL) -I$(LOCAL_LIB_PATH) -I$(RT_LIB_PATH) sbin/rt-setup-database --action drop --dba $(DB_DBA) --dba-password '' --force
 
-insert-approval-data: 
-       $(PERL) $(DESTDIR)/$(RT_SBIN_PATH)/insert_approval_scrips
 # }}}
 
 # {{{ libs-install
 libs-install: 
-       [ -d $(DESTDIR)/$(RT_LIB_PATH) ] || mkdir $(DESTDIR)/$(RT_LIB_PATH)
-       -cp -rp lib/* $(DESTDIR)/$(RT_LIB_PATH)
+@COMMENT_INPLACE_LAYOUT@       [ -d $(DESTDIR)$(RT_LIB_PATH) ] || $(INSTALL) -m 0755 -d $(DESTDIR)$(RT_LIB_PATH)
+@COMMENT_INPLACE_LAYOUT@       -( cd lib && find . -type d -print ) | while read dir ; do \
+@COMMENT_INPLACE_LAYOUT@           $(INSTALL) -m 0755 -d "$(DESTDIR)$(RT_LIB_PATH)/$$dir" ; \
+@COMMENT_INPLACE_LAYOUT@       done
+@COMMENT_INPLACE_LAYOUT@       -( cd lib && find . -type f -print ) | while read file ; do \
+@COMMENT_INPLACE_LAYOUT@            $(INSTALL) -m 0644 "lib/$$file" "$(DESTDIR)$(RT_LIB_PATH)/$$file" ; \
+@COMMENT_INPLACE_LAYOUT@       done
 # }}}
 
 # {{{ html-install
 html-install:
-       [ -d $(DESTDIR)/$(MASON_HTML_PATH) ] || mkdir $(DESTDIR)/$(MASON_HTML_PATH)
-       -cp -rp ./html/* $(DESTDIR)/$(MASON_HTML_PATH)
+@COMMENT_INPLACE_LAYOUT@       [ -d $(DESTDIR)$(MASON_HTML_PATH) ] || $(INSTALL) -m 0755 -d $(DESTDIR)$(MASON_HTML_PATH)
+@COMMENT_INPLACE_LAYOUT@       -( cd share/html && find . -type d -print ) | while read dir ; do \
+@COMMENT_INPLACE_LAYOUT@           $(INSTALL) -m 0755 -d "$(DESTDIR)$(MASON_HTML_PATH)/$$dir" ; \
+@COMMENT_INPLACE_LAYOUT@       done
+@COMMENT_INPLACE_LAYOUT@       -( cd share/html && find . -type f -print ) | while read file ; do \
+@COMMENT_INPLACE_LAYOUT@           $(INSTALL) -m 0644 "share/html/$$file" "$(DESTDIR)$(MASON_HTML_PATH)/$$file" ; \
+@COMMENT_INPLACE_LAYOUT@       done
+# }}}
+
+# {{{ font-install
+font-install:
+@COMMENT_INPLACE_LAYOUT@       [ -d $(DESTDIR)$(RT_FONT_PATH) ] || $(INSTALL) -m 0755 -d $(DESTDIR)$(RT_FONT_PATH)
+@COMMENT_INPLACE_LAYOUT@       -( cd share/fonts && find . -type f -print ) | while read file ; do \
+@COMMENT_INPLACE_LAYOUT@           $(INSTALL) -m 0644 "share/fonts/$$file" "$(DESTDIR)$(RT_FONT_PATH)/$$file" ; \
+@COMMENT_INPLACE_LAYOUT@       done
 # }}}
 
 # {{{ doc-install
 doc-install:
-       # RT 3.0.0 - RT 3.0.2 would accidentally create a file instead of a dir
-       -[ -f $(DESTDIR)/$(RT_DOC_PATH) ] && rm $(DESTDIR)/$(RT_DOC_PATH) 
-       [ -d $(DESTDIR)/$(RT_DOC_PATH) ] || mkdir $(DESTDIR)/$(RT_DOC_PATH)
-       -cp -rp ./README $(DESTDIR)/$(RT_DOC_PATH)
+@COMMENT_INPLACE_LAYOUT@       # RT 3.0.0 - RT 3.0.2 would accidentally create a file instead of a dir
+@COMMENT_INPLACE_LAYOUT@       -[ -f $(DESTDIR)$(RT_DOC_PATH) ] && rm $(DESTDIR)$(RT_DOC_PATH) 
+@COMMENT_INPLACE_LAYOUT@       [ -d $(DESTDIR)$(RT_DOC_PATH) ] || $(INSTALL) -m 0755 -d $(DESTDIR)$(RT_DOC_PATH)
+@COMMENT_INPLACE_LAYOUT@       -$(INSTALL) -m 0644 ./README $(DESTDIR)$(RT_DOC_PATH)/
 # }}}
 
 # {{{ etc-install
 
 etc-install:
-       mkdir -p $(DESTDIR)/$(RT_ETC_PATH)
-       -cp -rp \
-               etc/acl.* \
-               etc/initialdata \
-               etc/schema.* \
-               $(DESTDIR)/$(RT_ETC_PATH)
+@COMMENT_INPLACE_LAYOUT@       [ -d $(DESTDIR)$(RT_ETC_PATH) ] || $(INSTALL) -m 0755 -d $(DESTDIR)$(RT_ETC_PATH)
+@COMMENT_INPLACE_LAYOUT@       for file in $(ETC_FILES) ; do \
+@COMMENT_INPLACE_LAYOUT@           $(INSTALL) -m 0644 "etc/$$file" "$(DESTDIR)$(RT_ETC_PATH)/" ; \
+@COMMENT_INPLACE_LAYOUT@       done
 # }}}
 
 # {{{ sbin-install
 
 sbin-install:
-       mkdir -p $(DESTDIR)/$(RT_SBIN_PATH)
-       chmod +x sbin/rt-setup-database \
-               sbin/rt-test-dependencies
-       -cp -rp \
-               sbin/rt-setup-database \
-               sbin/rt-test-dependencies \
-               $(DESTDIR)/$(RT_SBIN_PATH)
+@COMMENT_INPLACE_LAYOUT@       $(INSTALL) -m 0755 -d $(DESTDIR)$(RT_SBIN_PATH)
+@COMMENT_INPLACE_LAYOUT@       for file in $(SYSTEM_BINARIES) ; do \
+@COMMENT_INPLACE_LAYOUT@           $(INSTALL) -o $(BIN_OWNER) -g $(RTGROUP) -m 0755 "sbin/$$file" "$(DESTDIR)$(RT_SBIN_PATH)/" ; \
+@COMMENT_INPLACE_LAYOUT@       done
 
 # }}}
 
 # {{{ bin-install
 
 bin-install:
-       mkdir -p $(DESTDIR)/$(RT_BIN_PATH)
-       chmod +x bin/rt-mailgate \
-               bin/rt-crontool
-       -cp -rp \
-               bin/rt-mailgate \
-               bin/mason_handler.fcgi \
-               bin/mason_handler.scgi \
-               bin/mason_handler.svc \
-               bin/rt \
-               bin/webmux.pl \
-               bin/rt-crontool \
-               $(DESTDIR)/$(RT_BIN_PATH)
-# }}}
+@COMMENT_INPLACE_LAYOUT@       $(INSTALL) -m 0755 -d $(DESTDIR)$(RT_BIN_PATH)
+@COMMENT_INPLACE_LAYOUT@       for file in $(BINARIES) ; do \
+@COMMENT_INPLACE_LAYOUT@           $(INSTALL) -o $(BIN_OWNER) -g $(RTGROUP) -m 0755 "bin/$$file" "$(DESTDIR)$(RT_BIN_PATH)/" ; \
+@COMMENT_INPLACE_LAYOUT@       done
 
 # {{{ local-install
 local-install:
-       -cp -rp ./local/html/* $(DESTDIR)/$(MASON_LOCAL_HTML_PATH)
-       -cp -rp ./local/po/* $(DESTDIR)/$(LOCAL_LEXICON_PATH)
-       -cp -rp ./local/etc/* $(DESTDIR)/$(LOCAL_ETC_PATH)
+       -( cd local/html && find . -type d -print ) | while read dir ; do \
+           $(INSTALL) -m 0755 -d "$(DESTDIR)$(MASON_LOCAL_HTML_PATH)/$$dir" ; \
+       done
+       -( cd local/html && find . -type f -print ) | while read file ; do \
+           $(INSTALL) -m 0644 "local/html/$$file" "$(DESTDIR)$(MASON_LOCAL_HTML_PATH)/$$file" ; \
+       done
+       -( cd local/po && find . -type d -print ) | while read dir ; do \
+           $(INSTALL) -m 0755 -d "$(DESTDIR)$(LOCAL_LEXICON_PATH)/$$dir" ; \
+       done
+       -( cd local/po && find . -type f -print ) | while read file ; do \
+           $(INSTALL) -m 0644 "local/po/$$file" "$(DESTDIR)$(LOCAL_LEXICON_PATH)/$$file" ; \
+       done
+       -( cd local/etc && find . -type d -print ) | while read dir ; do \
+           $(INSTALL) -m 0755 -d "$(DESTDIR)$(LOCAL_ETC_PATH)/$$dir" ; \
+       done
+       -( cd local/etc && find . -type f -print ) | while read file ; do \
+           $(INSTALL) -m 0644 "etc/$$file" "$(DESTDIR)$(LOCAL_ETC_PATH)/$$file" ; \
+       done
 # }}}
 
 # {{{ Best Practical Build targets -- no user servicable parts inside
 
-
-POD2TEST_EXE = sbin/extract_pod_tests
-
-testify-pods:
-       [ -d lib/t/autogen ] || mkdir lib/t/autogen
-       find lib -name \*pm |grep -v .svn | grep -v \*.in |xargs -n 1 $(PERL) $(POD2TEST_EXE)
-       find bin -type f |grep -v .svn | grep -v \~ | grep -v "\.in" | xargs -n 1 $(PERL) $(POD2TEST_EXE)
-
-
-
 regenerate-catalogs:
        $(PERL) sbin/extract-message-catalog
 
@@ -437,55 +508,29 @@ license-tag:
 factory: initialize-database
        cd lib; $(PERL) ../sbin/factory  $(DB_DATABASE) RT
 
-commit:
-       aegis -build ; aegis -diff ; aegis -test; aegis -develop_end
-
-integrate:
-       aegis -integrate_begin; aegis -build; aegis -diff; aegis -test ; aegis -integrate_pass
-
-predist: commit tag-and-tar
-
-tag-and-release-baseline:
-       aegis -cp -ind Makefile -output /tmp/Makefile.tagandrelease; \
-       $(MAKE) -f /tmp/Makefile.tagandrelease tag-and-release-never-by-hand
-
-
-# Running this target in a working directory is 
-# WRONG WRONG WRONG.
-# it will tag the current baseline with the version of RT defined 
-# in the currently-being-worked-on makefile. which is wrong.
-#  you want tag-and-release-baseline
-
-tag-and-release-never-by-hand:
-       aegis --delta-name $(TAG)
-       rm -rf /tmp/$(TAG)
-       mkdir /tmp/$(TAG)
-       cd /tmp/$(TAG); \
-               aegis -cp -ind -delta $(TAG) . ;\
-               make reconfigure;\
-               chmod 600 Makefile;\
-               aegis --report --project rt.$(RT_VERSION_MAJOR) \
-                     --page_width 80 \
-                     --page_length 9999 \
-                     --change $(RT_VERSION_MINOR) --output Changelog Change_Log
-
-       cd /tmp; tar czvf /home/ftp/pub/rt/devel/$(TAG).tar.gz $(TAG)/
-       chmod 644 /home/ftp/pub/rt/devel/$(TAG).tar.gz
-
-
 reconfigure:
        aclocal -I m4
        autoconf
        chmod 755 ./configure
        ./configure
 
-rpm:
-       (cd ..; tar czvf /usr/src/redhat/SOURCES/rt.tar.gz rt)
-       rpm -ba etc/rt.spec
+start-httpd:
+       $(PERL) bin/standalone_httpd &
 
+start-server:
+       $(PERL) sbin/rt-server &
 
 apachectl:
-       apachectl stop
-       sleep 3
-       apachectl start
+       $(APACHECTL) stop
+       sleep 10
+       $(APACHECTL) start
+       sleep 5
+
+SNAPSHOT=$(shell git describe --tags)
+snapshot:
+       git archive --prefix "$(SNAPSHOT)/"  HEAD | tar -xf -
+       ( cd $(SNAPSHOT) && autoconf && PERL=/usr/bin/perl ./configure )
+       tar -czf "$(SNAPSHOT).tar.gz" "$(SNAPSHOT)/"
+       rm -fr "$(SNAPSHOT)/"
+
 # }}}