remove rt from monitor package.
[monitor.git] / rt3 / monitor-rt3.init
index fdd64e8..0e24a11 100644 (file)
@@ -36,8 +36,8 @@ RT3_DB_NAME="rt3"
 
 WROTE_PG_CONFIG=
 
-if [ -z "$PLC_MONITOR_IP" ] ; then
-       PLC_MONITOR_IP=$( gethostbyname $PLC_MONITOR_HOST )
+if [ -z "$PLC_RT_IP" ] ; then
+       PLC_RT_IP=$( gethostbyname $PLC_RT_HOST )
 fi
 
 
@@ -54,6 +54,11 @@ function check_rt_siteconfig ()
 {
        tmp_siteconfig=$(mktemp)
        tmp_initialdata=$(mktemp)
+
+       # TODO: need a better approach for this.
+       for f in $MONITORPATH/rt3/rtconf.d/*.pl ; do 
+               update_config PLC_RT_HOSTNAME $PLC_RT_HOST $f
+       done
        
        # if the templates are newer than the actual config, then replace them.
        if [ $MONITORPATH/rt3/RT_SiteConfig.pm -nt /etc/rt3/RT_SiteConfig.pm ] ;
@@ -65,6 +70,7 @@ function check_rt_siteconfig ()
                # setup RT_SiteConfig.pm
                update_config PLC_NAME "$PLC_NAME" $tmp_siteconfig
                update_config PLC_RT_HOSTNAME $PLC_RT_HOST $tmp_siteconfig
+               update_config PLC_WWW_HOSTNAME $PLC_WWW_HOST $tmp_siteconfig
 
                update_config RT_DB_NAME $RT3_DB_NAME $tmp_siteconfig
                update_config RT_DB_USER $RT3_DB_USER $tmp_siteconfig
@@ -76,12 +82,19 @@ function check_rt_siteconfig ()
                # copy to live configuration
                cp -f $tmp_siteconfig /etc/rt3/RT_SiteConfig.pm 
                cp -f $tmp_initialdata /etc/rt3/initialdata 
+               chmod 644 /etc/rt3/RT_SiteConfig.pm 
+               chmod 644 /etc/rt3/initialdata 
 
                rm -f $tmp_siteconfig
                rm -f $tmp_initialdata
        fi
 }
 
+function check_rt_custom ()
+{
+       rsync -qv -az $MONITORPATH/rt3/local/html /usr/share/rt3
+}
+
 function check_rt_pghba ()
 {
        NAME=$RT3_DB_NAME
@@ -92,6 +105,7 @@ function check_rt_pghba ()
        if ! grep -q "$PATTERN" $CONF ; then
                #### SETUP ACCESS from postgres user to run init for the first time.
                echo "$PATTERN" >> $CONF
+               WROTE_PG_CONFIG="true"
        fi
 
 }
@@ -102,7 +116,7 @@ function check_rt_aliases ()
        if ! grep -q "rt-mailgate --queue support" /etc/aliases ; 
        then 
                sed -i -e "s/^support.*postmaster//g" /etc/aliases
-               sed -i -e "s/^security.*postmaster//g" /etc/aliases
+               sed -i -e "s/^security.*root//g" /etc/aliases
         cat <<EOF >> /etc/aliases
 # added by RT init scripts for default queues.
 support: "|/usr/sbin/rt-mailgate --queue support --action correspond --url http://localhost/rt3/"
@@ -119,43 +133,54 @@ function check_rt_init ()
 {
        if [ ! -f /etc/rt3/setup.finished ] ; then
                /usr/sbin/rt-setup-database --action init --dba postgres
+               for f in $MONITORPATH/rt3/rtconf.d/*.pl ; do 
+                       /usr/sbin/rt-setup-database --action insert --dba postgres --datafile $f
+               done
+
+               # run initial setup scripts (run only once, or for the first time)
+               for f in $MONITORPATH/rt3/rtsetup.d/*.{pl,py,sh} ; do 
+                       $f
+               done
+
                touch /etc/rt3/setup.finished
 
-       ###Last DB adjustments
-       #set defaultduein to 1 for support queue
-       cat <<EOF | /usr/bin/psql -U postgres -d $RT3_DB_NAME
-UPDATE queues SET defaultduein = 1 WHERE name='support'
-EOF
+       fi
+}
 
-       #alter acl for Everyone be able to create new tickets in support list
-       #Everyone (groups.id == 3) on support (queues.id == 1 (based on order in initialdata))
-       cat <<EOF | /usr/bin/psql -U postgres -d $RT3_DB_NAME
-INSERT INTO acl (principaltype,principalid,rightname,objecttype,objectid,delegatedby,delegatedfrom) VALUES ('Group',3,'CreateTicket','RT::Queue',1,0,0);
-INSERT INTO acl (principaltype,principalid,rightname,objecttype,objectid,delegatedby,delegatedfrom) VALUES ('Group',3,'ReplyToTicket','RT::Queue',1,0,0);
-EOF
-       #Everyone (groups.id == 3) on monitor ( queues.id == 2 (based on order in initaldata))
-       cat <<EOF | /usr/bin/psql -U postgres -d $RT3_DB_NAME
-INSERT INTO acl (principaltype,principalid,rightname,objecttype,objectid,delegatedby,delegatedfrom) VALUES ('Group',3,'CreateTicket','RT::Queue',2,0,0);
-INSERT INTO acl (principaltype,principalid,rightname,objecttype,objectid,delegatedby,delegatedfrom) VALUES ('Group',3,'ReplyToTicket','RT::Queue',2,0,0);
-EOF
-       #setup custom field values
-       cat <<EOF | /usr/bin/psql -U postgres -d $RT3_DB_NAME
-INSERT INTO objectcustomfields (customfield, objectid, sortorder, creator, lastupdatedby) VALUES (1,1,1,12,12);
-INSERT INTO customfields (name, "type", maxvalues, repeated, pattern, lookuptype, description, sortorder, creator, lastupdatedby,disabled) VALUES ('Problem Category', 'Select',1,0,'(?#Mandatory).','RT::Queue-RT::Ticket','How severe this problem is',0,12,12,0);
-EOF
-       cat <<EOF | /usr/bin/psql -U postgres -d $RT3_DB_NAME
-INSERT INTO customfieldvalues (customfield, name, sortorder, creator, lastupdatedby) VALUES (1,'Critical',0,12,12);
-INSERT INTO customfieldvalues (customfield, name, sortorder, creator, lastupdatedby) VALUES (1,'Major',1,12,12);
-INSERT INTO customfieldvalues (customfield, name, sortorder, creator, lastupdatedby) VALUES (1,'Minor',2,12,12);
-INSERT INTO customfieldvalues (customfield, name, sortorder, creator, lastupdatedby) VALUES (1,'Trivial',3,12,12);
-EOF
-       # give permissions to users to set this field.
-       cat <<EOF | /usr/bin/psql -U postgres -d $RT3_DB_NAME
-INSERT INTO acl (principaltype,principalid,rightname,objecttype,objectid,delegatedby,delegatedfrom) VALUES ('Group',3,'ModifyCustomField','RT::CustomField',1,0,0);
-INSERT INTO acl (principaltype,principalid,rightname,objecttype,objectid,delegatedby,delegatedfrom) VALUES ('Group',3,'SeeCustomField','RT::CustomField',1,0,0);
-EOF
+check_rt_sendmail ()
+{
+       tmp_sendmailmc=$(mktemp)
+       
+       # if the templates is newer than the processed config, then update it
+       if grep -q "Addr=127.0.0.1," /etc/mail/sendmail.mc  ; 
+       then
+               # copy templates
+               cp -f /etc/mail/sendmail.mc $tmp_sendmailmc
+
+               # setup initialdata
+               update_config "Addr=127.0.0.1," "" $tmp_sendmailmc
+
+               # copy to live configuration
+               cp -f $tmp_sendmailmc /etc/mail/sendmail.mc
+               rm -f $tmp_sendmailmc
+
+               # edit /etc/mail/access to add local IP
+               if ! grep "$PLC_RT_IP" /etc/mail/access ; then
+                       echo "$PLC_RT_IP                RELAY" >> /etc/mail/access
+                       makemap hash /etc/mail/access.db < /etc/mail/access
+               fi
+               if [ !  -f /etc/smrsh/rt-mailgate ] ; then
+                       ln -s /usr/sbin/rt-mailgate /etc/smrsh/rt-mailgate
+               fi
+               if ! grep "$PLC_RT_HOST" /etc/mail/local-host-names ; then
+                       # edit /etc/mail/local-host-names
+                       echo "$PLC_RT_HOST" >> /etc/mail/local-host-names
+               fi
+               m4 /etc/mail/sendmail.mc > /etc/mail/sendmail.cf
+               service sendmail restart
        fi
 
+
 }
 
 if [ "$PLC_RT_ENABLED" != "1" ] ; then
@@ -179,6 +204,8 @@ case "$1" in
                fi
                check_rt_aliases
                check_rt_init
+               check_rt_sendmail
+               check_rt_custom         # todo: restart httpd if needed.
 
                result "$MESSAGE"
        ;;
@@ -200,6 +227,9 @@ case "$1" in
                sed -i -e "s/.*mailgate.*//g" /etc/aliases
                rm -f /etc/rt3/setup.finished
 
+               sed -i -e "s/Port=smtp, Name=MTA/Port=smtp,Addr=127.0.0.1, Name=MTA/g" /etc/mail/sendmail.mc
+               service plc start httpd
+
                result "$MESSAGE"
        ;;