This wiki has undergone a migration to Confluence found Here
<meta name="googlebot" content="noindex">

Fulfillment Manager Conceptual Specification

From HL7Wiki
Revision as of 00:44, 27 November 2012 by Ployd (talk | contribs) (→‎Profiles)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Link back to solution specification

Overview

Service Description and Purpose

The Orders Fulfillment Service provides access to information regarding the fulfillment(s) of clinical services. It is separate and distinct from the actual capability services that:

  • support clinical processes (including but not necessarily limited to Labs, Images, and Consults)
  • the actual management of the Order Request itself
  • the actual delivery of information obtained in clinical processes and ordered via Order Requests.

This service is leveraged by the Request and Fulfillment Interoperability Pattern. It provides a consistent means of integrating certain capabilities between the components of a dispersed healthcare team working with different infrastructures, systems, standards, and business processes.


Scope

The Order Fulfillment Service describes a number of discrete steps in managing the fulfillment portion between members of a healthcare team that support request and fulfillment. Since these steps are common regardless of clinical service offered, they help to form a consistent pattern of behavior that may be applied in many situations. In so doing, the OF Service distinguishes between the order for a lab test, the promise of fulfillment, and the lab test itself, which may have a different lifecycle or which may serve a broader audience.


Reason why the service is necessary

The Order Fulfillment Service provides a key integrating component between systems involved in the distributed practice of patient-centric clinical care. It allows various systems performing clinical services to negotiate the fulfillment of requests for those services. This in turn provides a decoupling for these systems from the business processes invoked by healthcare practitioners. This separation of concerns also provides a clear boundary not only for its own capabilities, but for organizations engaged across organizational boundaries that need to share the business processes around request and fulfillment. Thus, for example, the Order Fulfillment Service enables a lab to operate completely independently from the Order Request system, and for the management of the clinical process to be managed separately from the financial management process that may happen in parallel. Additionally, this separation can happen at an institution or across several institutions or facilities.

Structure of the Service

The Fulfillment Manager Conceptual Diagram is shown below. The variation on the RequestFulfillment return value reflects the business flow difference between ambulatory and in-patient labs - in ambulatory, there is no return value, where in-patient returns a Promise.

FulfillmentManagementConceptual.png


Assumptions and Dependencies

The Order Fulfillment Service represents a series of components that may participate in complex conversations between multiple actors dealing with the management of orders and the promises associated with them. In some cases, the number of actors is arbitrary, growing in response to real time business judgments that are made through either machine or human mediation that alter the nature of the order / promise relationship. The Order Fulfillment Service creates distinct boundaries between responsibilities using these components, providing encapsulation supporting ownership of orders and ownership of promises for fulfillment. Thus, while any given implementation may only provide a single functional profile, these various profiles are intended to work together to form an appropriate abstraction of the ordering process.


Implementation Considerations

TBD

Detailed Functional Model for Each Operation

Request Fulfillment

  • Description: Allows an order manager to request fulfillment of an order
  • Pre-Conditions:
  1. The client has sufficient information to create the request
  2. User or requestor has permissions to create a request within the context
  • Conceptual Information Objects
    • Inputs: Order
    • Outputs: Promise
  • Post-Conditions:
  • Exception Conditions: None identified
  • Aspects left for Technical Bindings (optional)
  • Reference to Functional Profiles (optional)
  • Notes

Communicate Result

  • Description: Allows the fulfill to communicate a result to the requestor. This is a conceptual operation representing the "push" of a result from the Fulfiller to the Orderer - at the logical level it would be represented by several operations based on the message exchange pattern.
  • Pre-Conditions:
  1. A Result (preliminary or final) is available to be communicated to the orderer
  • Conceptual Information Objects
    • Inputs: Result
    • Outputs: Code
  • Post-Conditions:
  1. Result has been communicated and the receipt acknowledged
  • Exception Conditions:
  • Aspects left for Technical Bindings (optional)
  • Reference to Functional Profiles (optional)
  • Notes
    • This is a conceptual operation representing the "push" of a result from the Fulfiller to the Orderer - at the logical level it would be represented by several operations based on the message exchange pattern.

Cancel Order

  • Description: Used when a requstor (placer) would like for a previously requested, and not yet completed, order to not be performed.
  • Pre-Conditions:
  1. An order exists and the identifier is known
  2. The order is not completed
  3. The user or requestor has permission to update an order
  • Conceptual Information Objects
    • Inputs: Order, Order Identifier
    • Outputs: Order
  • Post-Conditions:
  1. The order referenced by order identifier has been cancelled and will not be acted upon.
  2. The cancel order identifier is returned
  • Exception Conditions:
  1. Order is not known to the fulfiller
  2. Order has already been completed

Retrieve Result

  • Description: Allows a requestor to retrieve a result from the fulfiller with using the result identifier
  • Pre-Conditions:
  1. The result identifier has been previously communicated to the fulfiller.
  • Conceptual Information Objects
    • Inputs: Result Identifier
    • Outputs: Result
  • Post-Conditions
  • Exception Conditions
  • Aspects left for Technical Bindings (optional)
  • Reference to Functional Profiles (optional)
  • Notes


Profiles

TBD

Introduction

Functional Profiles

Information Profiles

Recommendations for Conformance and Compliance

These will be elaborated in the next round of specification development