The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
NAME
    RT::Extension::ExtractCustomFieldValues - extract CF values from email
    headers or body

DESCRIPTION
    ExtractCustomFieldValues provides an "ExtractCustomFieldValues" scrip
    action, which can be used to scan incoming emails to set values of
    custom fields.

INSTALLATION
    "perl Makefile.PL"
    "make"
    "make install"
        May need root permissions

    "make initdb"
        Only run this the first time you install this module.

        If you run this twice, you may end up with duplicate data in your
        database.

        If you are upgrading this module, check for upgrading instructions
        in case changes need to be made to your database.

    Edit your /opt/rt4/etc/RT_SiteConfig.pm
        Add this line:

            Set(@Plugins, qw(RT::Extension::ExtractCustomFieldValues));

        or add "RT::Extension::ExtractCustomFieldValues" to your existing
        @Plugins line.

    Restart your webserver

USAGE
    To use the ScripAction, create a Template and a Scrip in RT. Your new
    Scrip should use a ScripAction of 'Extract Custom Field Values'. The
    Template consists of the lines which control the scanner. All
    non-comment lines are of the following format:

        <cf-name>|<Headername>|<MatchString>|<Postcmd>|<Options>

    where:

    *cf-name*
        The name of a custom field (must be created in RT). If this field is
        blank, the match will be run and Postcmd will be executed, but no
        custom field will be updated. Use this if you need to execute other
        RT code based on your match.

    *Headername*
        Either a Name of an email header, "body" to scan the body of the
        email or "headers" to search all of the headers.

    *MatchString*
        A regular expression to find a match in the header or body. If the
        MatchString matches a comma separated list and the CF is a
        multi-value CF then each item in the list is added as a separate
        value.

    *Postcmd*
        Perl code to be evaluated on $value, where $value is either $1 or
        full match text from the match performed with <MatchString>

    *Options*
        A string of letters which may control some aspects. Possible options
        include:

        *q* - (quiet)
            Don't record a transaction when adding the custom field value

        *** - (wildcard)
            The MatchString regex should contain _two_ capturing groups, the
            first of which is the CF name, the second of which is the value.
            If this option is given, the <cf-name> field is ignored.
            (Supercedes '+'.)

        *+* - (multiple)
            The MatchString regex will be applied with the /g option and all
            matching values will be added to the CF, which should probably
            be a multi-value CF for best results. (Superceded by '*'.)

  Separator
    You can change the separator string (initially "\|") during the template
    with:

        Separator=<anyregexp>

    Changing the separator may be necessary, if you want to use a "|" in one
    of the patterns in the controlling lines.

  Example and further reading
    An example template with some further examples is installed during "make
    initdb". See the CustomFieldScannerExample template for examples and
    further documentation.

AUTHOR
    This extension was originally written by Dirk Pape
    <pape@inf.fu-berlin.de>.

    This version is modified by Best Practical for customer use and
    maintained by Best Practical Solutions.

BUGS
    All bugs should be reported via email to
    bug-RT-Extension-ExtractCustomFieldValues@rt.cpan.org
    <mailto:bug-RT-Extension-ExtractCustomFieldValues@rt.cpan.org> or via
    the web at rt.cpan.org
    <http://rt.cpan.org/Public/Dist/Display.html?Name=RT-Extension-ExtractCu
    stomFieldValues>.

SUPPORT
    Support requests should be referred to Best Practical
    <sales@bestpractical.com>.

LICENSE AND COPYRIGHT
    This software is Copyright (c) 2007-2013 by Best Practical Solutions,
    LLC.

    This is free software, licensed under:

      The GNU General Public License, Version 2, June 1991