NAME
    RT::Extension::MoveRules - control ticket movements between queues

DESCRIPTION
    If you move tickets between queues a lot then probably you want to
    control this process. This extension allows you to configure rules which
    are required to move a ticket from a queue to another queue, for example
    if custom field X is equal to Y then a ticket can be moved from queue A
    to B. As well you can define which fields should be set before move.

INSTALLATION
    This extension works with RT 3.8 and depends on RT::Condition::Complex.
    Otherwise installation process is usuall:

        perl Makefile.PL
        make
        make install

CONFIGURATION
    Extension is controlled with one config option @MoveRules with the
    following syntax:

        Set( @MoveRules,
            {
                From       => 'queue',
                To         => 'queue',
                Rule       => 'a rule',
                Condition  => 'a rule',
                ShowAction => 1/0,

            },
            ...
        );

  From and To
    These keys define queues either by name or id. Both are mandatory
    options. Example:

        Set( @MoveRules,
            { From => 'X', To => 'Y' },
        );

    Such configuration allows users to move tickets from queue "X" to "Y",
    but not any other move.

  ShowAction
    Boolean option that controls whether action for this move is displayed
    in the action menu (Open, Take) or not. By default no actions are
    displayed.

  Rule
    Rule is a condition defining additional limits on the move. This is a
    string with syntax implemented by RT::Condition::Complex and
    RT::Extension::ColumnMap. Syntax is close to TicketSQL, slightly
    different, some examples:

        Rule => 'Subject = "good" AND Status = "open"',

  Condition
    Condition is very similar to "Rule". The difference is that users can
    not see a condition until they try to move a ticket.

    Moving limits between condition is up to you, but probably condition is
    better to leave with checks if a field is empty or not. For example:

        Condition => 'CustomField{"X"} is not empty',

LICENSE
    Under the same terms as perl itself.

AUTHOR
    Ruslan Zakirov <Ruslan.Zakirov@gmail.com>