CentOS 5.2 минимальная установка
http://www.ptitov.net/2008/07/request-tracker-installation-o.html
Обновляемся после установки
wget -c http://dag.wieers.com/rpm/packages/RPM-GPG-KEY.dag.txt
rpm --import RPM-GPG-KEY.dag.txt
wget -c http://packages.sw.be/rpmforge-release/rpmforge-release-0.3.6-1.el5.rf.i386.rpm
yum install rpmforge-release-0.3.6-1.el5.rf.i386.rpm
yum install yum-priorities
add line to [base], [updates], [addons]
priority=1
add line to [extras], [centosplus]
priority=2
add line to [rpmforge]
priority=12
Доставляем пакеты:
httpd \
httpd-devel \
apr-devel \
mysql \
mysql-devel \
mod_perl \
freetype-devel \
gd-devel \
libjpeg-devel \
libpng-devel \
libidn-devel \
gnutls-devel \
gcc \
perl-Apache-DBI \
perl-Apache-Session \
perl-Archive-Tar \
perl-CSS-Squish \
perl-Calendar-Simple \
perl-DBD-mysql \
perl-DBIx-SearchBuilder \
perl-DateTime-Locale \
perl-FCGI \
perl-File-ShareDir \
perl-HTML-Format \
perl-HTML-Scrubber \
perl-HTTP-Server-Simple \
perl-HTTP-Server-Simple-Mason \
perl-IO-Socket-INET6 \
perl-Locale-Maketext-Fuzzy \
perl-Locale-Maketext-Lexicon \
perl-Log-Dispatch \
perl-MIME-Types \
perl-Mail-GnuPG \
perl-Module-Refresh \
perl-Module-Versions-Report \
perl-Net-DNS \
perl-Net-Server \
perl-PerlIO-eol \
perl-Regexp-Common \
perl-TermReadKey \
perl-Test-Expect \
perl-Test-Inline \
perl-Test-WWW-Mechanize \
perl-Text-Quoted \
perl-Text-Template \
perl-Text-WikiFormat \
perl-Text-Wrapper \
perl-Time-modules \
perl-Tree-Simple \
perl-XML-RSS \
perl-XML-Simple \
perl-Net-SNMP \
perl-LDAP \
perl-GraphViz
Настраиваем cpan
perl -MCPAN -e shell
cpan -i Net::LDAP
useradd rt3 -d /opt/rt3
Добавим пользователя apache а группу rt3
./configure --with-web-handler=modperl2 --with-db-type=mysql
make testdeps
make fixdeps
make testdeps
make install
Если обновляемся то:
make upgrade
Ставим msmtp:
http://msmtp.sourceforge.net/
configure --prefix=/opt/msmtp
make
make install
/opt/rt3/etc/msmtp_wrapper.conf
account default
host smtp.gmail.com
port 587
auth on
user ithelp@myreis.ru
password ***
tls on
tls_trust_file /etc/pki/tls/certs/ca-bundle.crt
logfile /opt/rt3/var/log/msmtp.log
from ithelp@myreis.ru
/opt/rt3/etc/msmtp_wrapper
#!/bin/bash
/opt/msmtp/bin/msmtp -t -C /opt/rt3/etc/msmtp_wrapper.conf
/usr/bin/logger -t RTmailer -p syslog.info -- CALL /opt/msmtp/bin/msmtp -nt "$@" RETURNED $?
Добавляем плагин для аутентификации в LDAP:
httpd.conf:
KeepAlive On
NameVirtualHost *:80
ServerName vm-rt.alliancetravel.ru
ServerAlias vm-rt
Создаем конфиг в апаче:
ServerName rt.alliancetravel.ru
ServerAlias rt
Redirect permanent / https://rt.alliancetravel.ru/
ServerName rt.alliancetravel.ru
ServerAlias rt
ServerAdmin it@myreis.ru
SSLCertificateKeyFile /etc/pki/tls/private/localhost.key
SSLCertificateFile /etc/pki/tls/certs/rt.crt
DocumentRoot /opt/rt3/share/html
AddDefaultCharset UTF-8
PerlRequire /opt/rt3/bin/webmux.pl
Order allow,deny
Allow from all
SetHandler perl-script
PerlResponseHandler RT::Mason
SSLEngine on
Правим файл RT_SiteConfig.pm
Set(@Plugins, qw(RT::Authen::ExternalAuth), qw(RT::FM));
Set( $rtname, 'myreis.ru');
Set($WebBaseURL , "http://rt.alliancetravel.ru");
Set( $WebPath , "");
Set($DataBaseType , 'mysql');
Set($DatabaseHost , 'mysql.alliancetravel.ru');
Set($DatabaseRTHost , 'vm-rt.alliancetravel.ru');
Set($DatabaseName , 'rt38');
Set($DatabaseUser, 'rt_user');
Set($DatabasePassword , '***');
Set($Timezone, 'Europe/Moscow');
Set($SendmailPath , "/opt/rt3/etc/msmtp_wrapper");
Set($CorrespondAddress, 'rt@myreis.ru');
Set($CommentAddress, 'rt-comment@myreis.ru');
Set($RTAddressRegexp, '^rt(-comment)?\@(myreis|moyreys|moireis.ru|moyreis.ru|alliance-travel)\.(ru)$');
Set($OwnerEmail, 'it@myreis.ru');
Set($AutoCreate, {Privileged => 1});
Set($LdapExternalAuth, 1);
Set($LdapExternalInfo, 1);
Set($LdapAutoCreateNonLdapUsers, 1);
Set($LdapRTAttrMatchList, ['Name']);
Set($LdapEmailAttrMatchList, ['mail']);
Set($LdapServer, 'ldap.alliancetravel.ru:3268');
Set($LdapUser, 'cn=ldapsearch,ou=_specialAccounts,dc=alliancetravel,dc=ru');
Set($LdapPass, '***');
Set($LdapBase, 'dc=alliancetravel,dc=ru');
Set($LdapUidAttr, 'sAMAccountName');
Set($LdapFilter, '(&(objectclass=user)(objectclass=person))');
Set($LdapSSLVersion, 3);
Set($ExternalAuthPriority, ['My_LDAP']);
Set($ExternalInfoPriority, ['My_LDAP']);
Set($ExternalSettings, {
'My_LDAP' => {
'type' => 'ldap',
'auth' => 1,
'info' => 1,
'server' => 'ldap.alliancetravel.ru',
'user' => 'cn=ldapsearch,ou=_specialAccounts,dc=alliancetravel,dc=ru',
'pass' => 'UcWelAlRaHutatcitu',
'base' => 'dc=alliancetravel,dc=ru',
'filter' => '(&(objectclass=user)(objectclass=person))',
'd_filter' => '(userAccountControl=66050)',
'tls' => 0,
'net_ldap_args' => [ version => 3 ],
# 'group' => 'CN=DL_RT_Users,OU=_Resourses,DC=alliancetravel,DC=ru',
# 'group_attr' => 'member',
'attr_match_list' => ['Name', 'EmailAddress'],
'attr_map' => { 'Name' => 'sAMAccountName',
'EmailAddress' => 'mail',
'Organization' => 'company',
'RealName' => 'cn',
'ExternalAuthId' => 'sAMAccountName',
'Gecos' => 'sAMAccountName',
'HomePhone' => 'homePhone',
'WorkPhone' => 'telephoneNumber',
'MobilePhone' => 'mobile',
'PagerPhone' => 'pager',
'Address1' => 'streetAddress',
'City' => 'l',
'State' => 'st',
'Zip' => 'postalCode',
'Country' => 'co'
}
}
}
);
1;
RTFM
Ставим RTFM
/opt/rt3/sbin/rt-setup-database --dba root --dba-password uekmrf --action init
/opt/rt3/sbin/rt-setup-database --action schema --dba rt_user --dba-password Nekgeudas --datadir /opt/rt3/local/plugins/RT-FM/etc
/opt/rt3/.fetchmailrc:
poll pop.gmail.com
proto pop3
port 995
username rt@myreis.ru
password 'Nekgeudas'
mda "/opt/rt3/bin/rt-mailgate --url http://rt.alliancetravel.ru --action correspond --queue General"
ssl
username rt-comment@myreis.ru
password 'Nekgeudas'
mda "/opt/rt3/bin/rt-mailgate --url http://rt.alliancetravel.ru --action comment --queue General"
ssl
username ithelp@myreis.ru
password 'Nekgeudas'
mda "/opt/rt3/bin/rt-mailgate --url http://rt.alliancetravel.ru --action correspond --queue ithelpdesk"
ssl
username ithelp-comments@myreis.ru
password 'Nekgeudas'
mda "/opt/rt3/bin/rt-mailgate --url http://rt.alliancetravel.ru --action comment --queue ithelpdesk"
ssl
chown rt /opt/rt3 /opt/rt3/.fetchmailrc
chmod 600 /opt/rt3/.fetchmailrc
su rt3 -c "crontab -e":
*/1 * * * * /usr/bin/fetchmail -s
Templates
Autoreply
Subject: АвтоОтвет: {$Ticket->Subject}
Здравствуйте.
Нет необходимости отвечать на это письмо прямо сейчас.
Это сообщение создано автоматически системой регистрации заявок
Вашей заявке:
"{$Ticket->Subject()}",
присвоен номер:
[{$Ticket->QueueObj->SubjectTag || $rtname} #{$Ticket->id()}].
Если вы хотите сообщить дополнительную информацию по существующей проблемме,
пожалуйста, добавьте эту строку:
[{$Ticket->QueueObj->SubjectTag || $rtname} #{$Ticket->id}]
в тему вашего письма. Также, можно просто ответить на это письмо.
Большое спасибо.
{$Ticket->QueueObj->CorrespondAddress()}
Краткая информация о заявке представлена ниже.
-------------------------------------------------------------------------
{$Transaction->Content()}
Transaction
RT-Attach-Message: yes
{$Transaction->CreatedAsString}: Заявка {$Ticket->id} в работе.
Действие: {$Transaction->Description}
Очередь: {$Ticket->QueueObj->Name}
Тема: {$Transaction->Subject || $Ticket->Subject || "(Нет темы)"}
Ответственный: {$Ticket->OwnerObj->Name}
Заявитель: {$Ticket->RequestorAddresses}
Статус: {$Ticket->Status}
Ticket
{$Transaction->Content()}
Admin Comment
Subject: [Comment] {my $s=($Transaction->Subject||$Ticket->Subject); $s =~ s/\[Comment\]//g; $s =~ s/^Re//i; $s;}
{RT->Config->Get('WebURL')}Ticket/Display.html?id={$Ticket->id}
Это коментарий, он не будет выслан запросившим:
{$Transaction->Content()}
Status Change
Subject: Статус изменен: {$Transaction->NewValue}
{RT->Config->Get('WebURL')}Ticket/Display.html?id={$Ticket->id}
{$Transaction->Content()}
Resolved
Subject: Готово: {$Ticket->Subject}
Проблема с которой вы столкнулись решена,
если есть новые замечания по этой проблеме, пожалуйста,
Ответьте на это письмо.
-------------------------------------------------------------------------
{$Ticket->Subject}
Forward
Переадресация #{ $Transaction->id } заявки #{ $Ticket->id }
Error: Missing dashboard
Subject: [{RT->Config->Get('rtname')}] Не найдена инормационная панель!
Здравствуйте,
Вы подписались на инормационную панель, которой не существует. Скорее всего, инормационная панель была удалена.
Система удалит эту подписку за не надобностью. Ниже представлена инормация о вашей подписке:
Инфо панель: { $SubscriptionObj->SubValue('DashboardId') }
Частота: { $SubscriptionObj->SubValue('Frequency') }
Час: { $SubscriptionObj->SubValue('Hour') }
{
$SubscriptionObj->SubValue('Frequency') eq 'weekly'
? "Day of week: " . $SubscriptionObj->SubValue('Dow')
: $SubscriptionObj->SubValue('Frequency') eq 'monthly'
? "Day of month: " . $SubscriptionObj->SubValue('Dom')
: ''
}
Создаем Пользователей, Группы, Очереди ...
Создаем группу: Administrators, ithelpdesk, ithelpdeskManagers, RTFMAuthors, RTFMAdmins
Раздаем членство в группах:
EveryOne
Administrators
ithelpdesk
ithelpdeskManagers
RTFMAuthors
RTFMAdmins
Создаем Очередь
Queue Name: ithelpdesk
Description: Заявки в ИТ отдел
Subject Tag: ИТ отдел
Reply Address: ithelp@myreis.ru
Comment Address: ithelp-comments@myreis.ru
Раздаем права:
Global:
Для группы EveryOne: ModifySelf
Для группы Administrators: SuperUser
Очередь ithelpdesk
группе EveryOne: CreateTicket, ReplyToTicket
группе ithelpdesk: DeleteTicket, ModifyTicket, OwnTicket, SeeQueue, ShowTicket, TakeTicket, Watch
группе ithelpdeskManagers: AdminQueue, StealTicket, WatchAsAdminCce
Для очереди ithelpdesk назначаем Наблюдателей CC: группа ithelpdesk, Admin CC: группа ithelpdeskManagers
RTFM
Даем группе Everyone права: SeeClass, ShowArticle
Даем все права группе RTFMAdmins
Даем группе RTFMAuthors права: CreateArticle, ModifyArticle, ModifyArticleTopics, ShowArticleHistory
Комментариев нет:
Отправить комментарий