NAME
    RT-Extension-ChangeManagement - Change Management configuration for RT

RT VERSION
    Works with RT 5.

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

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

            Plugin('RT::Extension::ChangeManagement');

    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.

    Clear your mason cache
            rm -rf /opt/rt5/var/mason_data/obj

    Restart your webserver

DESCRIPTION
    This extension provides the configuration to implement a change
    management process in Request Tracker
    <https://bestpractical.com/request-tracker>.

    Organizations working to standardize internal processes for ISO or SOC
    compliance must have a standardized way to deploy and track changes to
    software, hardware, infrastructure, etc. This extension implements a
    change management system within RT, providing a framework for handling a
    variety of change types. It uses all core RT features, so everything can
    be modified as needed to align with your organization's practices and
    procedures. As-is, it provides a simple, fully functional implementation
    of an ITIL-like change management process.

    To provide additional validation and required fields for different
    stages of the process, you can install
    RT::Extension::MandatoryOnTransition. An example configuration is
    provided in the sample configuration file in
    etc/ChangeManagement_Config.pm.

    We've provided a walkthrough video <https://youtu.be/uQEEf7SGlkg> to
    demonstrate some of the functionality available in the change management
    extension.

  Change Management Queue
    After installing, you'll see a new queue called Change Management for
    tracking all of the incoming change requests. You can change the name to
    anything you like after installing. In a typical configuration, you will
    also want to assign an RT email address, like *changes@example.com* or
    *crb@example.com* (Change Review Team) to create tickets in this queue.

   Rights
    By default, Everyone can see the queue, create tickets, and view
    tickets. All users can also set custom fields on create, but only then.
    You can grant more rights if your change requestors need to update
    custom fields after the ticket is created.

    The Change Management group has more rights to work on change tickets
    including taking ownership and approving or rejecting requests.

    Some custom rights are available if you go to Admin > Queues, click on
    Change Management, then click Group Rights. The "Status changes" tab has
    specific rights to allow users to "Approve Requests" and "Implement
    Changes". By default, the Change Reviewer role can "Approve Requests"
    and the Change Implementor role can "Implement Changes". If this is too
    restrictive for your workflow, you can grant these to more users,
    possibly via a group.

  Custom Roles
    The roles below are allow you to assign different users to parts of the
    change management process. In addition to clearly identifying who is
    responsible for parts of the process, these roles can be used to manage
    rights and notifications like email.

    Change Reviewer
        Person who reviews incoming change requests, and is responsible for
        approving or denying a change request.

    Change Implementor
        Person who is responsible for implementing a change request.

  Groups
    Groups are included to make it easy to add users quickly and give them
    sufficient rights to interact with the Change Management queue.

    The Change Management group gives a set of rights appropriate for staff
    who will work with chagne management tickets. It allows them to take
    tickets, comment, change custom fields, etc. You can refine all of these
    after you install the extension.

  Change Management Lifecycle
    The Change Management lifecycle provides a set of common statuses. You
    can update this as needed to add or remove statuses and transitions.

    Requested
        Status given to a new change request. Indicates than a change has
        been requested and is awaiting approval.

    Approved
        For changes that are approved but not yet implemented.

    In Progress
        An approved change that is in the process of being deployed.

    Partially Deployed
        The change has been partially deployed; it is either taking an
        unusually long time to complete, or part of the deployment succeeded
        while another part failed. Reasons as to why should be detailed in a
        comment.

    Deployed
        The change has been deployed successfully.

    Failed
        The change failed to deploy. Reasons should be detailed in a
        comment.

    Cancelled
        This change was cancelled. Reasoning should be provided in a
        comment.

    Rejected
        The change was rejected by the review team. Reasoning should be
        provided in a comment on the ticket.

  Custom Fields
    Some common custom fields are provided to track additional information
    about changes. The provided custom fields can be modified as needed, to
    add or remove available values in dropdowns, for example.

    You can also add more custom fields as needed. A %CustomFieldGroupings
    configuration is provided to group custom fields in a Change Management
    portlet. You can add new custom fields to this configuration to include
    them in this section.

   Change Category
    Specifies the kind of change that is to be performed.

   Change Type
    One of the three types of changes. The initial values are those outlined
    in ITIL:

    Standard
        A low risk, pre-authorized change that follows a repeatable process.
        This is the default for new tickets in the Change Management queue.

    Emergency
        A change that must be performed ASAP, potentially bypassing approval
        steps.

    Normal
        Any change that doesn't fall into the other types.

   Rollback Plan
    A description of the steps necessary to perform a rollback of the
    proposed changes in the event that the deployment process is
    unsuccessful.

   Change Started
    Date that the change was started. This is not the same as the normal
    Started date on the ticket. Started is set when the ticket is moved to
    an open status (such as approved); Change Started is when someone
    actually started implementing the change.

    A scrip is provided to automatically set this when status changes to in
    progress or partially deployed.

   Change Complete
    Date that the change was successfully deployed. A scrip is provided to
    automatically set this when status changes to deployed.

  Change Management Dashboard
    A Change Management dashboard is installed with two saved searches
    included, one for upcoming changes and one for recently completed
    changes. These are useful for tracking change tickets and are also good
    examples of the types of saved searches and dashboards you can create
    for different participants in the change process.

CUSTOMIZING AND EXTENDING
    Since this extension uses core RT features, it's easy for an RT
    administrator to customize various parts. Below are some ideas.

  Additional Custom Fields
    Some ideas of fields that could be added to the change management
    process might include:

    Change Origin
        Customer, Vendor, Internal. Dropdown.

    Location
        Datacenter, customer site, etc. Text.

    Implementation Steps
        Steps needed to implement proposed change. Text.

    Validation Steps
        Process for validating a change was deployed successfully. Text.

    Impact Assessment
        A description of what potential side effects of a proposed change
        might be, what could happen if the change goes awry, etc. Text.

   Making Custom Fields Required
    Using RT::Extension::MandatoryOnTransition, any of the above fields can
    be made required upon a status change. For example, you may wish to make
    Implementation Steps, Validation Steps, and Impact Assessment required
    fields before a change request can be approved. See
    etc/ChangeManagement_Config.pm for a ready-to-use example with the out
    of the box configuration.

   Default Values for Custom Fields
    As an RT admin, you can go to Admin > Queues > Change Management, then
    click on Default Values in the submenu. From that page, you can set or
    change the default values for assigned custom fields.

AUTHOR
    Best Practical Solutions, LLC <modules@bestpractical.com>

    All bugs should be reported via email to
        bug-RT-Extension-ChangeManagement@rt.cpan.org
    or via the web at
        http://rt.cpan.org/Public/Dist/Display.html?Name=RT-Extension-ChangeManagement
LICENSE AND COPYRIGHT
    This software is Copyright (c) 2022 by Best Practical Solutions, LLC.

    This is free software, licensed under:

      The GNU General Public License, Version 2, June 1991